题解 | #链表相加(二)#大数加法过来的#

链表相加(二)

http://www.nowcoder.com/practice/c56f6c70fb3f4849bc56e33ff2a50b6b

 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */

class Solution {
public:
        string solve(string s, string t) 
        {
        // write code here
        int len_s_ = s.size();
        int len_t_ = t.size();
        
        int jinwei=0;//进位
        int gewei = 0;//个位
        
        stack<char> res;
        
        for(int i=len_s_-1,j=len_t_-1;i>=0||j>=0;i--,j--)
        {
            int s_n = '0',t_n='0';
            
            if(i>=0) s_n = s[i];
            
            if(j>=0) t_n = t[j];
            
            int now = s_n-'0'+t_n-'0'+jinwei;
            
            jinwei = now/10;
            now%=10;
            
            res.push(now+'0');
        }
        
        if(jinwei!=0) res.push(jinwei+'0');
        
        string res_;
        
        while(!res.empty()) 
        {
            res_.push_back(res.top());
                res.pop();
        }
        
        return res_;
    }
    
    string int_generate_str(ListNode* p)
    {
        string res;
        
        for(ListNode* tmp = p;tmp!=nullptr;tmp=tmp->next)
            res+='0'+tmp->val;


        return res;
    }
    
    ListNode* str_transfer_list(string str)
    {
        ListNode* res = new ListNode(-1);
        ListNode* point = res;
        
        for(char c:str)
        {
            ListNode* p=new ListNode(c-'0');
            point->next = p;
            point = point->next;
        }
        
        return res->next;
    }
    
    ListNode* addInList(ListNode* head1, ListNode* head2) {
        
        return str_transfer_list(solve(int_generate_str(head1), int_generate_str(head2)));
    }
};


    

全部评论

相关推荐

Southyeung:我说一下我的看法(有冒犯实属抱歉):(1)简历不太美观,给我一种看都不想看的感觉,感觉字体还是排版问题;(2)numpy就一个基础包,机器学习算法是什么鬼?我感觉你把svm那些写上去都要好一点。(2)课程不要写,没人看,换成获奖经历;(3)项目太少了,至少2-3个,是在不行把网上学习的也写上去。
点赞 评论 收藏
分享
05-21 15:47
门头沟学院 Java
浪漫主义的虹夏:项目有亮点吗,第一个不是纯玩具项目吗,项目亮点里类似ThreadLocal,Redis储存说难听点是花几十分钟绝大部分人都能学会,第二个轮子项目也没体现出设计和技术,想实习先沉淀,好高骛远的自嗨只会害了自己
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务