?? 題目描述
🌟 leetcode鏈接:https://leetcode.cn/problems/add-strings/description/
ps:
從兩個字符串的末尾開始遍歷,依次相加,若大于等于 10
則使用一個變量記錄進位,遍歷的時候若兩個字符串其中一個結束,那么結束的字符串的當前位就用 0
來與另一個字符串相加。這里可以使用頭插但是頭插需要挪動數據,效率比較低,時間復雜度是 O ( N 2 ) O(N^2) O(N2),所以可以使用尾插,最后逆置即可,這種思路的時間復雜度為 O ( N ) O(N) O(N)。
還有一種特殊的情況是:5 + 5 = 10
兩個字符串只有一個數,而且兩個字符串的 val
相加后是同時都為結束,但是進位還有一個 1
所以還要判斷這種特殊情況。
代碼:
class Solution {
public:string addStrings(string num1, string num2) {// 從兩個字符串的末尾 依次相加 進位int end1 = num1.size() - 1;int end2 = num2.size() - 1;string ans;// 記錄進位int unit = 0;while (end1 >= 0 || end2 >= 0) {// 若當前任意一個字符串結束 那么默認為0int val1 = end1 >= 0 ? num1[end1] - '0' : 0;int val2 = end2 >= 0 ? num2[end2] - '0' : 0;// 尾插ans += (val1 + val2 + unit) % 10 + '0';// 大于10進位unit = val1 + val2 + unit >= 10 ? 1 : 0;end1--;end2--;}// 特殊情況:進位還存在if (unit) {ans += '1';}// 逆置 傳迭代區間 左閉右開reverse(ans.begin() , ans.end());return ans;}
};