牛客题霸 NC1 大数加法题解

大数加法

http://www.nowcoder.com/questionTerminal/11ae12e8c6fe48f883cad618c2e81475

class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     * 计算两个数之和
     * @param s string字符串 表示第一个整数
     * @param t string字符串 表示第二个整数
     * @return string字符串
     */
    string solve(string s, string t) {
        string ans="";
        int sS = s.size();
        int tS = t.size();
        int carry = 0;
        for( int i=sS-1,j=tS-1; i>=0||j>=0; i--,j-- ){
            int a = i>=0 ? s[i]-'0' : 0;
            int b = j>=0 ? t[j]-'0' : 0;
            int sum = a+b;
            ans = to_string((sum+carry) % 10 ) + ans;
            if( sum+carry>=10 ){
                carry = 1;
            } else {
                carry = 0;
            }
        }
        if( carry )
            ans = '1' + ans;
        return ans;
    }
};

思路:
模拟加减法,从两个数的最后一位开始加。
遇到需要进位使用carry进行标注。

全部评论
请教一下,这种代码是怎么写出来的,没有主函数啊,是自己现在下边测试好然后照猫画虎改的吗?
1 回复 分享
发布于 2021-02-26 20:59
你这是一点不会啊
点赞 回复 分享
发布于 2021-05-12 17:05

相关推荐

不愿透露姓名的神秘牛友
07-16 14:00
机械打工仔:来挂自己了,经典巨婴从校园投入职场
点赞 评论 收藏
分享
06-25 16:25
梧州学院 Java
愿汐_:项目介绍那么长,然而你做了啥就一句话?
点赞 评论 收藏
分享
07-02 10:39
门头沟学院 Java
Steven267:说点真实的,都要秋招了,还没有实习,早干嘛去了,本来学历就差,现在知道急了,而且你这个简历完全可以写成一页,劣势太大了,建议转测试
点赞 评论 收藏
分享
难怪不开摄像头,全是简单的性格题,比大疆友善多了
NULL10086:今早上发的测评,我这还没做呢,官网上已经显示挂了
投递大疆等公司7个岗位
点赞 评论 收藏
分享
评论
3
1
分享

创作者周榜

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