亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++ LeetCode1775通過最少操作次數(shù)使數(shù)組和相等

 更新時間:2022年12月16日 14:26:29   作者:LetMeFly  
這篇文章主要為大家介紹了C++ LeetCode1775通過最少操作次數(shù)使數(shù)組和相等,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

LeetCode1775.通過最少操作次數(shù)使數(shù)組的和相等

力扣題目鏈接:leetcode.cn/problems/eq…

給你兩個長度可能不等的整數(shù)數(shù)組 nums1 和 nums2 。兩個數(shù)組中的所有值都在 1 到 6 之間(包含 1 和 6)。

每次操作中,你可以選擇 任意 數(shù)組中的任意一個整數(shù),將它變成 1 到 6 之間 任意 的值(包含 1 和 6)。

請你返回使 nums1 中所有數(shù)的和與 nums2 中所有數(shù)的和相等的最少操作次數(shù)。如果無法使兩個數(shù)組的和相等,請返回 -1 。

示例 1:

輸入:nums1 = [1,2,3,4,5,6], nums2 = [1,1,2,2,2,2]
輸出:3
解釋:你可以通過 3 次操作使 nums1 中所有數(shù)的和與 nums2 中所有數(shù)的和相等。以下數(shù)組下標(biāo)都從 0 開始。
- 將 nums2[0] 變?yōu)?6 。 nums1 = [1,2,3,4,5,6], nums2 = [<strong>6</strong>,1,2,2,2,2] 。
- 將 nums1[5] 變?yōu)?1 。 nums1 = [1,2,3,4,5,<strong>1</strong>], nums2 = [6,1,2,2,2,2] 。
- 將 nums1[2] 變?yōu)?2 。 nums1 = [1,2,<strong>2</strong>,4,5,1], nums2 = [6,1,2,2,2,2] 。

示例 2:

輸入:nums1 = [1,1,1,1,1,1,1], nums2 = [6]
輸出:-1
解釋:沒有辦法減少 nums1 的和或者增加 nums2 的和使二者相等。

示例 3:

輸入:nums1 = [6,6], nums2 = [1]
輸出:3
解釋:你可以通過 3 次操作使 nums1 中所有數(shù)的和與 nums2 中所有數(shù)的和相等。以下數(shù)組下標(biāo)都從 0 開始。
- 將 nums1[0] 變?yōu)?2 。 nums1 = [<strong>2</strong>,6], nums2 = [1] 。
- 將 nums1[1] 變?yōu)?2 。 nums1 = [2,<strong>2</strong>], nums2 = [1] 。
- 將 nums2[0] 變?yōu)?4 。 nums1 = [2,2], nums2 = [<strong>4</strong>] 。

提示:

  • 1 <= nums1.length, nums2.length <= 105
  • 1 <= nums1[i], nums2[i] <= 6

方法一:貪心 + 計數(shù)

兩個數(shù)組中的元素的初始和可能不同。為了方便,我們假設(shè)第一個數(shù)組的元素和小于第二個數(shù)組(不是的話交換兩個數(shù)組的地址即可)

那么,我們的任務(wù)就是,將第一個數(shù)組中的元素變大,或者將第二個數(shù)組中的元素減小,使得兩個數(shù)組中的元素和相等。

因為數(shù)字的合法范圍是111到666,因此,第一個數(shù)組中,我們盡量讓小的元素優(yōu)先變成666,這樣所帶來的“和的增加”最多。

同理,第二個數(shù)組中,我們盡量讓大的元素變成111,這樣所帶來的“和的減少”最多。

因此,我們可以預(yù)處理一遍兩個數(shù)組,計算出兩個數(shù)組中“和的差值”,并統(tǒng)計兩個數(shù)組中1到6的元素的個數(shù)

然后,我們將第一個數(shù)組中的“1”變成“6”,同時將第二個數(shù)組中的“6”變成“1”,直到“沒有元素可變”或“差值小于等于0”

接著,我們將第一個數(shù)組中的“2”變成“6”,同時將第二個數(shù)組中的“5”變成“1”,直到“沒有元素可變”或“差值小于等于0”

......

這樣,我們每次修改元素,都是“盡最大努力”地減小了兩個數(shù)組中的差值,這樣就能保證每次更改能“盡大可能”地縮小差值

這就是貪心

其實不難發(fā)現(xiàn),將第一個數(shù)組中的“1”變成“6”和將第二個數(shù)組中的“6”變成“1”所帶來的結(jié)果是等價的,因此,為了方便,我們可以直接將第二個數(shù)組中的“6”和第一個數(shù)組中的“1”統(tǒng)計到一起。

AC代碼

C++

class Solution {
public:
    int minOperations(vector<int>& nums1, vector<int>& nums2) {
        int s1 = accumulate(nums1.begin(), nums1.end(), 0);
        int s2 = accumulate(nums2.begin(), nums2.end(), 0);
        if (s1 > s2)
            swap(nums1, nums2);
        int times[6] = {0};
        for (int& t : nums1)
            times[t - 1]++;
        for (int& t : nums2)
            times[6 - t]++;
        int ans = 0;
        int loc = 0;
        int diff = abs(s2 - s1);
        while (diff) {
            int perChange = 6 - loc - 1;
            if (!perChange)
                break;
            int maxChange = times[loc] * perChange;
            int realChange = min(maxChange, diff);
            diff -= realChange;
            int changeTimes = realChange / perChange + (realChange % perChange != 0);
            ans += changeTimes;
            loc++;
        }
        return diff ? -1 : ans;
    }
};

以上就是C++ LeetCode1775通過最少操作次數(shù)使數(shù)組和相等的詳細(xì)內(nèi)容,更多關(guān)于C++ 最少操作數(shù)組和相等的資料請關(guān)注腳本之家其它相關(guān)文章!

  • C語言制作表白神器的示例代碼

    C語言制作表白神器的示例代碼

    這篇文章主要為大家詳細(xì)介紹了如何利用C語言制作一個簡單的表白神器,文中的示例代碼講解詳細(xì),具有一定的借鑒價值,感興趣的小伙伴可以了解一下
    2023-03-03
  • 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計-用棧實現(xiàn)表達(dá)式求值的方法詳解

    數(shù)據(jù)結(jié)構(gòu)課程設(shè)計-用棧實現(xiàn)表達(dá)式求值的方法詳解

    本篇文章是對在c語言中用棧實現(xiàn)表達(dá)式求值的方法進行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C++基于EasyX圖形庫實現(xiàn)2048小游戲

    C++基于EasyX圖形庫實現(xiàn)2048小游戲

    這篇文章主要為大家詳細(xì)介紹了C++基于EasyX圖形庫實現(xiàn)2048小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • C語言單鏈表實現(xiàn)通訊錄管理系統(tǒng)

    C語言單鏈表實現(xiàn)通訊錄管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語言單鏈表實現(xiàn)通訊錄管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • C++中delete和delete[]的區(qū)別詳細(xì)介紹

    C++中delete和delete[]的區(qū)別詳細(xì)介紹

    一直對C++中的delete和delete[]的區(qū)別不甚了解,今天遇到了,上網(wǎng)查了一下,得出了結(jié)論,拿出來和大家分享一下
    2012-11-11
  • C語言菜鳥基礎(chǔ)教程之單精度浮點數(shù)與雙精度浮點數(shù)

    C語言菜鳥基礎(chǔ)教程之單精度浮點數(shù)與雙精度浮點數(shù)

    在C語言中,單精度浮點數(shù)(float)和雙精度浮點數(shù)(double)類型都是用來儲存實數(shù)的,雙精度是用記憶較多,有效數(shù)字較多,數(shù)值范圍較大。
    2017-10-10
  • C++利用libcurl庫實現(xiàn)多線程文件下載

    C++利用libcurl庫實現(xiàn)多線程文件下載

    這篇文章主要為大家詳細(xì)介紹了C++如何利用libcurl庫實現(xiàn)多線程文件下載,文章的示例代碼講解詳細(xì),具有一定的借鑒價值,有需要的小伙伴可以參考下
    2024-01-01
  • C++數(shù)組和指針的區(qū)別與聯(lián)系

    C++數(shù)組和指針的區(qū)別與聯(lián)系

    這篇文章主要介紹了C++數(shù)組和指針的區(qū)別與聯(lián)系,數(shù)組是具有固定大小和連續(xù)內(nèi)存空間的相同數(shù)據(jù)集合,指針是指存放內(nèi)存地址的變量,更多詳細(xì)資料請參考下面文章內(nèi)容
    2022-01-01
  • C語言實現(xiàn)Fibonacci數(shù)列遞歸

    C語言實現(xiàn)Fibonacci數(shù)列遞歸

    這篇文章主要介紹了C語言實現(xiàn)Fibonacci數(shù)列遞歸,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • 最新評論