<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
原題連結 :
給定一個由 整數 組成的 非空 陣列所表示的非負整數,在該數的基礎上加一。
最高位數位存放在陣列的首位, 陣列中每個元素只儲存單個數位。
你可以假設除了整數 0 之外,這個整數不會以零開頭。
範例 1:
輸入:digits = [1,2,3] 輸出:[1,2,4] 解釋:輸入陣列表示數位 123。
範例 2:
輸入:digits = [4,3,2,1] 輸出:[4,3,2,2] 解釋:輸入陣列表示數位 4321。
範例 3:
輸入:digits = [0] 輸出:[1]
提示:
1 <= digits.length <= 100
0 <= digits[i] <= 9
對於一般的數位,直接在末位加一即可,
本題特殊的兩個點:
若加一之後的值為10,需要進一位
若數位為類似999 ,加一之後需要多一位數。使用insert()來實現, insert函數 : vec.insert(begin()+i ,a) 在第i個元素插入a
class Solution { public: vector<int> plusOne(vector<int>& digits) { int size = digits.size(); if(digits[size-1] != 9) //若末位不等於9,正常加一 { ++digits[size-1]; } else //若末位等於9,加一等於0 { digits[size-1] = 0; for(int i = size - 1; i >0; --i) //若加完一後若等於0,下一位要進一 如869 { if(digits[i] == 0) { digits[i-1] = (digits[i-1] + 1) % 10; } else break; //若某一位是數不需要進一,跳出迴圈 } if(digits[0] == 0) //若到最後最高位也等於0,需要多一位數 如99 + 1 此時為答案為00,進行一下操作 { digits.insert(digits.begin(),1); //在最高位插入1 } } return digits; } };
題目不長,但是還是有點拗口的感覺,首先要先弄明白題意,然後正常的思路下考慮進位的溢位等就可以解出來。
/** * @param {number[]} digits * @return {number[]} */ var plusOne = function(digits) { //先遍歷 從右向左 for(let i = digits.length-1;i>=0;i--){ if(digits[i] !==9){ digits[i]++ return digits; }else{ // 是 9 digits[i] = 0 } } let result = [1,...digits]; /* let result = [1].concat(digits); digits.unshift(1); */ return result; };
這是一道基礎的屬組倒序查詢的問題,唯一需要關注的就是類似[9,9]的場景,迴圈後需要看是否需要進位。
如果需要進位,則在陣列0位置插入1,才能保證接過的正確性。
class Solution: def plusOne(self, digits): count = 1 for i in range(len(digits) - 1, -1, -1): count, digits[i] = divmod(digits[i] + count, 10) if count == 0: break if count: digits.insert(0,count) return digits
倒著看,不為9,直接加1,返回:為9的話,需要進位,變成0即可;
特殊情況 9 99 等,一直為9的,結果肯定是10 ,100 陣列長度加1 ,首位為1
class Solution { public int[] plusOne(int[] digits) { int length = digits.length; // 最後一個不為九的數加1,為九的變0,9 99 單獨處理 for (int i = length - 1; i >= 0; i--) { if(digits[i] != 9){ digits[i] = digits[i] + 1; return digits; }else { digits[i] = 0; } } int[] ints = new int[length + 1]; ints[0] = 1; return ints; } }
以上就是go語言題解LeetCode66加一範例詳解的詳細內容,更多關於go題解LeetCode66加一的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45