當(dāng)前位置:首頁 > 公眾號(hào)精選 > 后端技術(shù)指南針
[導(dǎo)讀]1 前言 今天來寫一道leetcode的中等難度的題目,聲明一下:這不是最優(yōu)解,就是常規(guī)思路。 之所以寫出來,是因?yàn)槲矣X得:如果你的想法比較復(fù)雜或者比較冗長,那也沒關(guān)系,寫出來ac了它,能繞過層層關(guān)卡做出來同樣值得。 就好像我們新接手了同事的代碼,第一反

1 前言

今天來寫一道leetcode的中等難度的題目,聲明一下:這不是最優(yōu)解,就是常規(guī)思路。

之所以寫出來,是因?yàn)槲矣X得:如果你的想法比較復(fù)雜或者比較冗長,那也沒關(guān)系,寫出來ac了它,能繞過層層關(guān)卡做出來同樣值得。

就好像我們新接手了同事的代碼,第一反應(yīng)可能是這么復(fù)雜,但是竟然還能跑,所以盡管很繞,但是沒有把他繞暈,那么我覺得他也挺厲害的了。

工作中我就遇到過這樣的代碼,同事的開發(fā)能力比較強(qiáng),但是代碼風(fēng)格跟我差別很大,期間接過他一點(diǎn)代碼,可能是過設(shè)計(jì)了,但是運(yùn)行得很好。

在我們沒有做那么多題目的前提下,第一想法很重要,面試的時(shí)候往往很緊張,把握住你的第一想法去實(shí)現(xiàn)它,最終做出來足夠讓面試官覺得你還不錯(cuò),在此基礎(chǔ)上優(yōu)化就是加分。

有些題目的最優(yōu)解或者優(yōu)化解并不好想,如果不是acm打手或者天資異稟的高手還是有難度的。

所以不要嫌棄這不是最優(yōu)解,最起碼這是最容易想到的解法,當(dāng)然你們也可以覺得不是最優(yōu)解沒有意義,非要嫌棄鄙視一下,那也么得辦法,啊哈哈。

廢話不說,開車開車!

2.題目描述

給定兩個(gè)以字符串形式表示的非負(fù)整數(shù) num1 和 num2,
返回 num1 和 num2 的乘積,它們的乘積也表示為字符串形式。

示例 1:
輸入: num1 = "2", num2 = "3"
輸出: "6"

示例 2:
輸入: num1 = "123", num2 = "456"
輸出: "56088"

說明:
num1 和 num2 的長度小于110。
num1 和 num2 只包含數(shù)字 0-9。
num1 和 num2 均不以零開頭,除非是數(shù)字 0 本身。
不能使用任何標(biāo)準(zhǔn)庫的大數(shù)類型(比如 BigInteger)或直接將輸入轉(zhuǎn)換為整數(shù)來處理。

3.題目分析

這個(gè)題目描述也比較清晰了,就是給了兩個(gè)字符串格式的數(shù)字,讓返回兩個(gè)數(shù)的乘積字符串。

題目限定了不要使用bigint和輸入轉(zhuǎn)整數(shù)這種系統(tǒng)的機(jī)制,并且給定了num1和num2的長度小于110,這也說明了長度可能是100那么長,110位就已經(jīng)非常大了,所以不要考慮轉(zhuǎn)換整數(shù)的想法了。

其實(shí)這個(gè)問題很熟悉,這就是個(gè)計(jì)算器嘛,我們要把很長的兩個(gè)字符串相乘。

第一想法就是那模擬一下兩個(gè)數(shù)相乘的具體過程,再轉(zhuǎn)換為代碼,是的,這個(gè)想法就足夠了。

4.手動(dòng)模擬

來吧,有了第一想法,那就開始在紙上劃拉劃拉。

在紙上大致模擬了一下之后,基本上就能把握幾個(gè)點(diǎn)了:

  • 乘數(shù)和被乘數(shù)的兩個(gè)循環(huán)
    在計(jì)算循環(huán)過程中,涉及到一個(gè)默認(rèn)補(bǔ)0的過程,因?yàn)閿?shù)字所在的位不一樣,這樣是要注意的,這樣我們得到三個(gè)字符串,這三個(gè)字符串本質(zhì)上是逆序的,因?yàn)槲覀兪窍葟牡臀婚_始計(jì)算的。

  • 各個(gè)臨時(shí)結(jié)果的累加
    也就是圖中的第二部分,這里是把多個(gè)臨時(shí)結(jié)果累加就可以了,最開始我把第一部分的結(jié)果做了reverse,但是在第二部分累加時(shí)發(fā)現(xiàn)沒有必要,最后把結(jié)果reverse一下即可。

  • 細(xì)節(jié)問題
    在基本了解流程之后,肯定會(huì)有一些需要注意的致錯(cuò)細(xì)節(jié),這個(gè)很多時(shí)候是debug時(shí)發(fā)現(xiàn)的,這道題我代碼寫完之后debug出兩個(gè)錯(cuò)誤的點(diǎn),反過來想是細(xì)節(jié)考慮不周全。

4.我的糙代碼

代碼提交了幾次才通過,看下時(shí)間和空間:

無奈同行們太優(yōu)秀,被80%的同行大敗了,不過就算反面教材也可以看看吧:

class Solution {public: //將string指定位置的字符轉(zhuǎn)換為數(shù)字 int getvalue (string &num, int index){ return num[index]-'0'; }
//遍歷子結(jié)果字符串 累加 void calthem(vector<string> &resvec, int maxlen, string &resstr){ //按照最大長度開始從低位向高位遍歷 int veclen = resvec.size(); int jinwei = 0;
for(int i=0;i<maxlen;i++){ //開始遍歷每一次的結(jié)果 int this_sum = 0; this_sum += jinwei; for(int j=0;j<veclen;j++){ if(i<resvec[j].length()){ this_sum+=getvalue(resvec[j],i); } } jinwei = this_sum/10; int remain = this_sum%10; resstr+=to_string(remain); } if(jinwei!=0) resstr+=to_string(jinwei); reverse(resstr.begin(),resstr.end()); }
string multiply(string num1, string num2) { //特殊情況 string res(""); if(num1=="0"||num2=="0") return "0"; //其他情況 /* 1.完全模擬乘法的計(jì)算過程 2.使用兩個(gè)循環(huán) 增加每次計(jì)算的結(jié)果 以及進(jìn)位 3.由于要求不可直接將輸入轉(zhuǎn)換為整數(shù) 可以使用ascii來確定單個(gè)字符的數(shù)值 */ int len1 = num1.length(); int len2 = num2.length(); //存儲(chǔ)每次循環(huán)的結(jié)果 后續(xù)的累加 要從其中進(jìn)行遍歷 vector<string> resvec; int maxlen=0; //我們從乘數(shù) nums2開始作為外層循環(huán) 即456 并且從個(gè)位開始循環(huán) //為了對齊將結(jié)果后默認(rèn)補(bǔ)齊0 for(int i=len2-1;i>=0;i--){ int jinwei = 0; //從低位到高位循環(huán)被乘數(shù) 并初始化進(jìn)位 int outer = getvalue(num2,i); int zero_cnt = len2-1-i; string this_round_res=""; this_round_res.append(zero_cnt,'0'); for(int j=len1-1;j>=0;j--){ int inner = getvalue(num1,j); //計(jì)算兩個(gè)位的乘積 并取保留值和進(jìn)位 //eg 8*9=72 上一次進(jìn)位0 綜合得:保留位2 進(jìn)位7 int calres = inner*outer+jinwei; jinwei = calres/10; int remain = calres%10; //這里注意 乘積是從低位開始運(yùn)算的 因此需要注意方向問題 //為了方便解決 將低位放在字符串首位 高位依次追加 最后反轉(zhuǎn)即可 this_round_res+=to_string(remain); } if(jinwei!=0) this_round_res+=to_string(jinwei); maxlen = maxlen>=this_round_res.length()?maxlen:this_round_res.length(); resvec.push_back(this_round_res); } //累加vector中的數(shù)據(jù) calthem(resvec,maxlen,res); return res; }};

代碼好像還是比較長,不過本質(zhì)上就兩個(gè)部分,第一個(gè)是利用兩個(gè)循環(huán)獲得臨時(shí)結(jié)果字符串,把字符串存儲(chǔ)在vector中,第二部分就是把vector中的臨時(shí)字符串累加返回。

其中盡量不用api,能自己造的輪子就自己寫了,權(quán)當(dāng)一題多練了。

5.優(yōu)化解

我的糙代碼ac之后,慣例打開題解看看同行有什么妙招,其中有一個(gè)講的比較好,是對算數(shù)過程的優(yōu)化,說實(shí)話我的算數(shù)并不好,所以這個(gè)是第一次看到,現(xiàn)場我是想不到, 不過很有用一起看下:

這個(gè)優(yōu)化法是把計(jì)算過程中的值的坐標(biāo)都提前知道了,所以就相當(dāng)于一步到位,不過我還沒來得及實(shí)驗(yàn)可以快多少,等下試試。


最后依然是,感謝各位的觀摩!

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉