C++ LeetCode1775通過(guò)最少操作次數(shù)使數(shù)組和相等
LeetCode1775.通過(guò)最少操作次數(shù)使數(shù)組的和相等
力扣題目鏈接:leetcode.cn/problems/eq…
給你兩個(gè)長(zhǎng)度可能不等的整數(shù)數(shù)組 nums1
和 nums2
。兩個(gè)數(shù)組中的所有值都在 1
到 6
之間(包含 1
和 6
)。
每次操作中,你可以選擇 任意 數(shù)組中的任意一個(gè)整數(shù),將它變成 1
到 6
之間 任意 的值(包含 1
和 6
)。
請(qǐng)你返回使 nums1
中所有數(shù)的和與 nums2
中所有數(shù)的和相等的最少操作次數(shù)。如果無(wú)法使兩個(gè)數(shù)組的和相等,請(qǐng)返回 -1
。
示例 1:
輸入:nums1 = [1,2,3,4,5,6], nums2 = [1,1,2,2,2,2]
輸出:3
解釋:你可以通過(guò) 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
解釋:沒(méi)有辦法減少 nums1 的和或者增加 nums2 的和使二者相等。
示例 3:
輸入:nums1 = [6,6], nums2 = [1]
輸出:3
解釋:你可以通過(guò) 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
方法一:貪心 + 計(jì)數(shù)
兩個(gè)數(shù)組中的元素的初始和可能不同。為了方便,我們假設(shè)第一個(gè)數(shù)組的元素和小于第二個(gè)數(shù)組(不是的話交換兩個(gè)數(shù)組的地址即可)
那么,我們的任務(wù)就是,將第一個(gè)數(shù)組中的元素變大,或者將第二個(gè)數(shù)組中的元素減小,使得兩個(gè)數(shù)組中的元素和相等。
因?yàn)閿?shù)字的合法范圍是111到666,因此,第一個(gè)數(shù)組中,我們盡量讓小的元素優(yōu)先變成666,這樣所帶來(lái)的“和的增加”最多。
同理,第二個(gè)數(shù)組中,我們盡量讓大的元素變成111,這樣所帶來(lái)的“和的減少”最多。
因此,我們可以預(yù)處理一遍兩個(gè)數(shù)組,計(jì)算出兩個(gè)數(shù)組中“和的差值”,并統(tǒng)計(jì)兩個(gè)數(shù)組中1到6的元素的個(gè)數(shù)
然后,我們將第一個(gè)數(shù)組中的“1”變成“6”,同時(shí)將第二個(gè)數(shù)組中的“6”變成“1”,直到“沒(méi)有元素可變”或“差值小于等于0”
接著,我們將第一個(gè)數(shù)組中的“2”變成“6”,同時(shí)將第二個(gè)數(shù)組中的“5”變成“1”,直到“沒(méi)有元素可變”或“差值小于等于0”
......
這樣,我們每次修改元素,都是“盡最大努力”地減小了兩個(gè)數(shù)組中的差值,這樣就能保證每次更改能“盡大可能”地縮小差值
這就是貪心
其實(shí)不難發(fā)現(xiàn),將第一個(gè)數(shù)組中的“1”變成“6”和將第二個(gè)數(shù)組中的“6”變成“1”所帶來(lái)的結(jié)果是等價(jià)的,因此,為了方便,我們可以直接將第二個(gè)數(shù)組中的“6”和第一個(gè)數(shù)組中的“1”統(tǒng)計(jì)到一起。
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通過(guò)最少操作次數(shù)使數(shù)組和相等的詳細(xì)內(nèi)容,更多關(guān)于C++ 最少操作數(shù)組和相等的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- C/C++哈希表優(yōu)化LeetCode題解997找到小鎮(zhèn)的法官
- C/C++實(shí)現(xiàn)獲取系統(tǒng)時(shí)間的示例代碼
- C++ LeetCode1805字符串不同整數(shù)數(shù)目
- C++ LeetCode1812判斷國(guó)際象棋棋盤格子顏色
- C++ LeetCode1780判斷數(shù)字是否可以表示成三的冪的和
- C++ LeetCode300最長(zhǎng)遞增子序列
- C++?LeetCode1827題解最少操作使數(shù)組遞增
- C/C++題解LeetCode1295統(tǒng)計(jì)位數(shù)為偶數(shù)的數(shù)字
相關(guān)文章
C語(yǔ)言 二叉樹的鏈?zhǔn)酱鎯?chǔ)實(shí)例
本篇文章主要介紹C語(yǔ)言中二叉樹的鏈?zhǔn)酱鎯?chǔ),這里提供了一個(gè)實(shí)例代碼進(jìn)行參考,這樣對(duì)二叉樹的鏈?zhǔn)酱鎯?chǔ)有更深入的了解,希望能幫到學(xué)習(xí)這塊知識(shí)的同學(xué)2016-07-07數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-用棧實(shí)現(xiàn)表達(dá)式求值的方法詳解
本篇文章是對(duì)在c語(yǔ)言中用棧實(shí)現(xiàn)表達(dá)式求值的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05C++基于EasyX圖形庫(kù)實(shí)現(xiàn)2048小游戲
這篇文章主要為大家詳細(xì)介紹了C++基于EasyX圖形庫(kù)實(shí)現(xiàn)2048小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-02-02C語(yǔ)言單鏈表實(shí)現(xiàn)通訊錄管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言單鏈表實(shí)現(xiàn)通訊錄管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-05-05C++中delete和delete[]的區(qū)別詳細(xì)介紹
一直對(duì)C++中的delete和delete[]的區(qū)別不甚了解,今天遇到了,上網(wǎng)查了一下,得出了結(jié)論,拿出來(lái)和大家分享一下2012-11-11C語(yǔ)言菜鳥基礎(chǔ)教程之單精度浮點(diǎn)數(shù)與雙精度浮點(diǎn)數(shù)
在C語(yǔ)言中,單精度浮點(diǎn)數(shù)(float)和雙精度浮點(diǎn)數(shù)(double)類型都是用來(lái)儲(chǔ)存實(shí)數(shù)的,雙精度是用記憶較多,有效數(shù)字較多,數(shù)值范圍較大。2017-10-10C++利用libcurl庫(kù)實(shí)現(xiàn)多線程文件下載
這篇文章主要為大家詳細(xì)介紹了C++如何利用libcurl庫(kù)實(shí)現(xiàn)多線程文件下載,文章的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,有需要的小伙伴可以參考下2024-01-01C語(yǔ)言實(shí)現(xiàn)Fibonacci數(shù)列遞歸
這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)Fibonacci數(shù)列遞歸,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02