go語(yǔ)言題解LeetCode66加一示例詳解
題目描述
原題鏈接 :
給定一個(gè)由 整數(shù) 組成的 非空 數(shù)組所表示的非負(fù)整數(shù),在該數(shù)的基礎(chǔ)上加一。
最高位數(shù)字存放在數(shù)組的首位, 數(shù)組中每個(gè)元素只存儲(chǔ)單個(gè)數(shù)字。
你可以假設(shè)除了整數(shù) 0 之外,這個(gè)整數(shù)不會(huì)以零開(kāi)頭。
示例 1:
輸入:digits = [1,2,3] 輸出:[1,2,4] 解釋?zhuān)狠斎霐?shù)組表示數(shù)字 123。
示例 2:
輸入:digits = [4,3,2,1] 輸出:[4,3,2,2] 解釋?zhuān)狠斎霐?shù)組表示數(shù)字 4321。
示例 3:
輸入:digits = [0] 輸出:[1]
提示:
1 <= digits.length <= 100
0 <= digits[i] <= 9
思路分析
對(duì)于一般的數(shù)字,直接在末位加一即可,
本題特殊的兩個(gè)點(diǎn):
若加一之后的值為10,需要進(jìn)一位
若數(shù)字為類(lèi)似999 ,加一之后需要多一位數(shù)。使用insert()來(lái)實(shí)現(xiàn), insert函數(shù) : vec.insert(begin()+i ,a) 在第i個(gè)元素插入a
AC 代碼
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,下一位要進(jìn)一 如869 { if(digits[i] == 0) { digits[i-1] = (digits[i-1] + 1) % 10; } else break; //若某一位是數(shù)不需要進(jìn)一,跳出循環(huán) } if(digits[0] == 0) //若到最后最高位也等于0,需要多一位數(shù) 如99 + 1 此時(shí)為答案為00,進(jìn)行一下操作 { digits.insert(digits.begin(),1); //在最高位插入1 } } return digits; } };
小結(jié)
題目不長(zhǎng),但是還是有點(diǎn)拗口的感覺(jué),首先要先弄明白題意,然后正常的思路下考慮進(jìn)位的溢出等就可以解出來(lái)。
JavaScript 66題
代碼
/** * @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; };
python3 循環(huán)判斷
分析:
這是一道基礎(chǔ)的屬組倒序查找的問(wèn)題,唯一需要關(guān)注的就是類(lèi)似[9,9]的場(chǎng)景,循環(huán)后需要看是否需要進(jìn)位。
如果需要進(jìn)位,則在數(shù)組0位置插入1,才能保證接過(guò)的正確性。
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
JAVA解決進(jìn)位問(wèn)題
解題思路
倒著看,不為9,直接加1,返回:為9的話,需要進(jìn)位,變成0即可;
特殊情況 9 99 等,一直為9的,結(jié)果肯定是10 ,100 數(shù)組長(zhǎng)度加1 ,首位為1
代碼
class Solution { public int[] plusOne(int[] digits) { int length = digits.length; // 最后一個(gè)不為九的數(shù)加1,為九的變0,9 99 單獨(dú)處理 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語(yǔ)言題解LeetCode66加一示例詳解的詳細(xì)內(nèi)容,更多關(guān)于go題解LeetCode66加一的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- Go語(yǔ)言題解LeetCode1266訪問(wèn)所有點(diǎn)的最小時(shí)間示例
- go語(yǔ)言題解LeetCode1275找出井字棋的獲勝者示例
- go語(yǔ)言題解LeetCode1299將每個(gè)元素替換為右側(cè)最大元素
- go語(yǔ)言題解LeetCode88合并兩個(gè)有序數(shù)組示例
- Go語(yǔ)言題解LeetCode35搜索插入位置示例詳解
- go語(yǔ)言題解LeetCode228匯總區(qū)間示例詳解
- go語(yǔ)言題解LeetCode453最小操作次數(shù)使數(shù)組元素相等
- Go語(yǔ)言題解LeetCode1260二維網(wǎng)格遷移示例詳解
相關(guān)文章
go調(diào)用shell命令兩種方式實(shí)現(xiàn)(有無(wú)返回值)
本文主要介紹了go調(diào)用shell命令兩種方式實(shí)現(xiàn)(有無(wú)返回值),主要用于執(zhí)行shell命令,并且返回shell的標(biāo)準(zhǔn)輸出,具有一定的參考價(jià)值,感興趣的可以了解一下2021-12-12Golang協(xié)程常見(jiàn)面試題小結(jié)
本文主要介紹了Golang協(xié)程常見(jiàn)面試題小結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02詳解如何使用Golang實(shí)現(xiàn)Cron定時(shí)任務(wù)
定時(shí)任務(wù)是許多應(yīng)用程序中常見(jiàn)的一種需求,它們可以用于執(zhí)行定期的清理任務(wù),發(fā)送通知,生成報(bào)告等,在這篇博客中,我們將介紹如何在Go語(yǔ)言中使用robfig/cron包來(lái)實(shí)現(xiàn)Cron定時(shí)任務(wù),需要的朋友可以參考下2024-04-04Golang的Crypto/SHA256庫(kù)實(shí)戰(zhàn)指南
無(wú)論是在保護(hù)數(shù)據(jù)安全、驗(yàn)證數(shù)據(jù)完整性,還是在構(gòu)建復(fù)雜的安全系統(tǒng)中,crypto/sha256都是Golang程序員不可或缺的工具,本文主要介紹了Golang的Crypto/SHA256庫(kù)實(shí)戰(zhàn)指南,感興趣的可以了解一下2024-02-02Go Gin框架中的路由組及其優(yōu)先級(jí)探索分析
在構(gòu)建Web應(yīng)用程序時(shí),理解和有效地使用路由是至關(guān)重要的,Go語(yǔ)言的Gin框架為此提供了強(qiáng)大的工具,特別是通過(guò)其路由組功能,本文將深入探討Gin的RouterGroup,特別是在路徑匹配和優(yōu)先級(jí)方面的行為2024-01-01golang編程入門(mén)之http請(qǐng)求天氣實(shí)例
這篇文章主要介紹了golang編程入門(mén)之http請(qǐng)求天氣實(shí)例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-08-08