每周一道算法題(三十四)

本周題目難度‘Medium'材原,使用語言'C'

題目:本次的題目挺有意思的,就是給你兩個低于110位的數(shù)(以字符串形式給你)扼雏,讓你求積后以字符串形式返回結(jié)果南捂。

思路:這個題的思路很簡單,就是實現(xiàn)起來會有很多坑缸兔。方法有很多種日裙,我的思路是將兩個數(shù)的每一位相乘,然后求和惰蜜,最后處理下數(shù)位的問題即可昂拂,當然之間涉及到很多類型轉(zhuǎn)換的問題。具體的還是看代碼吧:

char* multiply(char* num1, char* num2) {
    //確定長度
    int len1 = strlen(num1);
    int len2 = strlen(num2);
    //如果有一個是0抛猖,直接返回0
    if (len1 == 1 && num1[0] == '0') return "0";
    if (len2 == 1 && num2[0] == '0') return "0";
    //創(chuàng)建容器并初始化
    char* result = malloc(sizeof(char) * (len1 + len2 + 1));
    for (int i = 0; i < (len1+len2); i++) {
        result[i] = '0';
    }
    result[(len1+len2)] = '\0';
    
    for (int i = 0; i < len1; i++) {
        for (int j = 0; j < len2; j++) {
            //用num1的每一位去乘以num2
            int tempNum = (num1[i] - '0') * (num2[j] - '0');   
            //確定是第幾位
            int index =  i + j + 1;
            //求和
            int lowCount = (result[index] - '0') + (tempNum % 10);
            result[index] = lowCount % 10 + '0'; 
            //是否需要進位
            if (lowCount > 9 || tempNum > 9) {  
                int temp = tempNum > 9 ? (result[index - 1] - '0') + (tempNum / 10) : (result[index-1] - '0');
                lowCount = lowCount > 9 ? temp + 1 : temp;
                result[index-1] = lowCount % 10 + '0';
                int addOne = 2;
                //大于10就循環(huán)進位
                while (lowCount > 9) {
                    lowCount = (result[index-addOne] - '0') + 1;
                    result[index - addOne] = (lowCount % 10 + '0');
                    addOne++;
                }
            }
        }
    }
    //位數(shù)處理
    if (result[0] == '0') {
        for (int i = 0; i < (len1+len2); i++) {
            result[i] = result[i+1];
        }
    }
    //返回結(jié)果
    return result;
}

效率一般格侯,還有的思路是8位數(shù)8位數(shù)相乘,這樣并不會越界财著,可以提高效率联四,有興趣的小伙伴也可以嘗試一下。

版權(quán)聲明:本文為 Crazy Steven 原創(chuàng)出品撑教,歡迎轉(zhuǎn)載朝墩,轉(zhuǎn)載時請注明出處!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市伟姐,隨后出現(xiàn)的幾起案子收苏,更是在濱河造成了極大的恐慌,老刑警劉巖愤兵,帶你破解...
    沈念sama閱讀 218,386評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件鹿霸,死亡現(xiàn)場離奇詭異,居然都是意外死亡秆乳,警方通過查閱死者的電腦和手機懦鼠,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評論 3 394
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來矫夷,“玉大人葛闷,你說我怎么就攤上這事∷海” “怎么了淑趾?”我有些...
    開封第一講書人閱讀 164,704評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長忧陪。 經(jīng)常有香客問我扣泊,道長近范,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,702評論 1 294
  • 正文 為了忘掉前任延蟹,我火速辦了婚禮评矩,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘阱飘。我一直安慰自己斥杜,他們只是感情好,可當我...
    茶點故事閱讀 67,716評論 6 392
  • 文/花漫 我一把揭開白布沥匈。 她就那樣靜靜地躺著蔗喂,像睡著了一般。 火紅的嫁衣襯著肌膚如雪高帖。 梳的紋絲不亂的頭發(fā)上缰儿,一...
    開封第一講書人閱讀 51,573評論 1 305
  • 那天,我揣著相機與錄音散址,去河邊找鬼乖阵。 笑死,一個胖子當著我的面吹牛预麸,可吹牛的內(nèi)容都是我干的瞪浸。 我是一名探鬼主播,決...
    沈念sama閱讀 40,314評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼师崎,長吁一口氣:“原來是場噩夢啊……” “哼默终!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起犁罩,我...
    開封第一講書人閱讀 39,230評論 0 276
  • 序言:老撾萬榮一對情侶失蹤齐蔽,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后床估,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體含滴,經(jīng)...
    沈念sama閱讀 45,680評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,873評論 3 336
  • 正文 我和宋清朗相戀三年丐巫,在試婚紗的時候發(fā)現(xiàn)自己被綠了谈况。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,991評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡递胧,死狀恐怖碑韵,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情缎脾,我是刑警寧澤祝闻,帶...
    沈念sama閱讀 35,706評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站遗菠,受9級特大地震影響联喘,放射性物質(zhì)發(fā)生泄漏华蜒。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,329評論 3 330
  • 文/蒙蒙 一豁遭、第九天 我趴在偏房一處隱蔽的房頂上張望叭喜。 院中可真熱鬧,春花似錦蓖谢、人聲如沸捂蕴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽启绰。三九已至,卻和暖如春沟使,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背渊跋。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評論 1 270
  • 我被黑心中介騙來泰國打工腊嗡, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人拾酝。 一個月前我還...
    沈念sama閱讀 48,158評論 3 370
  • 正文 我出身青樓燕少,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蒿囤。 傳聞我的和親對象是個殘疾皇子客们,可洞房花燭夜當晚...
    茶點故事閱讀 44,941評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 這次的算法題寫的比較low,效率非常低,不過和我一起做這個算法題的小伙伴們用的暴搜沒通過所有的測試,這我還是比較欣...
    CrazySteven閱讀 672評論 2 1
  • 本周的算法題難度級別依舊是'Easy',也很簡單 題目:找出所有字符串中最長的公共前綴 思路:提供兩個思路,一個思...
    CrazySteven閱讀 692評論 0 3
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,139評論 25 707
  • 本周題目的難度是‘EASY'所以為了追求效率材诽,著實也是搞了好幾天底挫,下面就來分享一下搞這題的心路歷程。脸侥。建邓。 題目:判...
    CrazySteven閱讀 882評論 3 8
  • 今天是周四又到了我們一周一次的美育特色課。 打了下課鈴我們就回到教室了睁枕,我收拾好書包官边,拿著籃球就沖向操...
    楊浩然五年級三班閱讀 174評論 0 0