欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

go語言題解LeetCode66加一示例詳解

 更新時(shí)間:2022年12月30日 15:04:22   作者:劉09k11  
這篇文章主要為大家介紹了go語言題解LeetCode66加一示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

題目描述

原題鏈接 :

66. 加一

給定一個(gè)由 整數(shù) 組成的 非空 數(shù)組所表示的非負(fù)整數(shù),在該數(shù)的基礎(chǔ)上加一。

最高位數(shù)字存放在數(shù)組的首位, 數(shù)組中每個(gè)元素只存儲(chǔ)單個(gè)數(shù)字。

你可以假設(shè)除了整數(shù) 0 之外,這個(gè)整數(shù)不會(huì)以零開頭。

示例 1:

輸入:digits = [1,2,3]
輸出:[1,2,4]
解釋:輸入數(shù)組表示數(shù)字 123。

示例 2:

輸入:digits = [4,3,2,1]
輸出:[4,3,2,2]
解釋:輸入數(shù)組表示數(shù)字 4321。

示例 3:

輸入:digits = [0]
輸出:[1]

提示:

1 <= digits.length <= 100

0 <= digits[i] <= 9

思路分析

對(duì)于一般的數(shù)字,直接在末位加一即可,

本題特殊的兩個(gè)點(diǎn):

若加一之后的值為10,需要進(jìn)一位

若數(shù)字為類似999 ,加一之后需要多一位數(shù)。使用insert()來實(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é)

題目不長,但是還是有點(diǎn)拗口的感覺,首先要先弄明白題意,然后正常的思路下考慮進(jìn)位的溢出等就可以解出來。

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ǔ)的屬組倒序查找的問題,唯一需要關(guān)注的就是類似[9,9]的場景,循環(huán)后需要看是否需要進(jìn)位。

如果需要進(jìn)位,則在數(shù)組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

JAVA解決進(jìn)位問題

解題思路

倒著看,不為9,直接加1,返回:為9的話,需要進(jìn)位,變成0即可;

特殊情況 9 99 等,一直為9的,結(jié)果肯定是10 ,100 數(shù)組長度加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語言題解LeetCode66加一示例詳解的詳細(xì)內(nèi)容,更多關(guān)于go題解LeetCode66加一的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Golang嵌入資源文件實(shí)現(xiàn)步驟詳解

    Golang嵌入資源文件實(shí)現(xiàn)步驟詳解

    在應(yīng)用程序中附帶代碼以外的其他資源可能會(huì)很有用,常用的實(shí)現(xiàn)方法是嵌入對(duì)象或數(shù)據(jù)。在數(shù)據(jù)庫中存儲(chǔ)數(shù)據(jù)應(yīng)用中,需要定義schema,在應(yīng)用啟動(dòng)時(shí)創(chuàng)建表,但如果找不到schema文件呢?Go1.16提供embed包讓實(shí)現(xiàn)變得簡單,之前很多第三方包實(shí)現(xiàn)類似功能
    2023-01-01
  • go調(diào)用shell命令兩種方式實(shí)現(xiàn)(有無返回值)

    go調(diào)用shell命令兩種方式實(shí)現(xiàn)(有無返回值)

    本文主要介紹了go調(diào)用shell命令兩種方式實(shí)現(xiàn)(有無返回值),主要用于執(zhí)行shell命令,并且返回shell的標(biāo)準(zhǔn)輸出,具有一定的參考價(jià)值,感興趣的可以了解一下
    2021-12-12
  • Golang協(xié)程常見面試題小結(jié)

    Golang協(xié)程常見面試題小結(jié)

    本文主要介紹了Golang協(xié)程常見面試題小結(jié),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • 詳解如何使用Golang實(shí)現(xiàn)Cron定時(shí)任務(wù)

    詳解如何使用Golang實(shí)現(xiàn)Cron定時(shí)任務(wù)

    定時(shí)任務(wù)是許多應(yīng)用程序中常見的一種需求,它們可以用于執(zhí)行定期的清理任務(wù),發(fā)送通知,生成報(bào)告等,在這篇博客中,我們將介紹如何在Go語言中使用robfig/cron包來實(shí)現(xiàn)Cron定時(shí)任務(wù),需要的朋友可以參考下
    2024-04-04
  • Golang的Crypto/SHA256庫實(shí)戰(zhàn)指南

    Golang的Crypto/SHA256庫實(shí)戰(zhàn)指南

    無論是在保護(hù)數(shù)據(jù)安全、驗(yàn)證數(shù)據(jù)完整性,還是在構(gòu)建復(fù)雜的安全系統(tǒng)中,crypto/sha256都是Golang程序員不可或缺的工具,本文主要介紹了Golang的Crypto/SHA256庫實(shí)戰(zhàn)指南,感興趣的可以了解一下
    2024-02-02
  • GO中Json解析的幾種方式

    GO中Json解析的幾種方式

    本文主要介紹了GO中Json解析的幾種方式,詳細(xì)的介紹了幾種方法,?文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-01-01
  • 詳解golang?defer?閉包?匿名函數(shù)

    詳解golang?defer?閉包?匿名函數(shù)

    這篇文章主要介紹了golang?defer?閉包?匿名函數(shù)的相關(guān)知識(shí),本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07
  • Go Gin框架中的路由組及其優(yōu)先級(jí)探索分析

    Go Gin框架中的路由組及其優(yōu)先級(jí)探索分析

    在構(gòu)建Web應(yīng)用程序時(shí),理解和有效地使用路由是至關(guān)重要的,Go語言的Gin框架為此提供了強(qiáng)大的工具,特別是通過其路由組功能,本文將深入探討Gin的RouterGroup,特別是在路徑匹配和優(yōu)先級(jí)方面的行為
    2024-01-01
  • go-cache的基本使用場景示例解析

    go-cache的基本使用場景示例解析

    這篇文章主要為大家介紹了go-cache的基本使用場景示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • golang編程入門之http請(qǐng)求天氣實(shí)例

    golang編程入門之http請(qǐng)求天氣實(shí)例

    這篇文章主要介紹了golang編程入門之http請(qǐng)求天氣實(shí)例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-08-08

最新評(píng)論