[八我司] 介绍一下Uber tech stack和各个大组的情况

一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
E轮2.5亿美元融资
K12教育独角兽一起作业
北京-诚聘人工智能/教育/大数据岗
坐标湾区
Games Startup
招聘游戏开发工程师
游戏初创公司招聘工程师、UIUX Designer和游戏策划
码农求职神器Triplebyte:
不用海投
内推多家公司面试
把贵司招聘信息放这里
查看: 2311|回复: 4
收起左侧

求一发bigInt的代码

[复制链接] |试试Instant~ |关注本帖
syftalent 发表于 2016-2-11 00:43:34 | 显示全部楼层 |阅读模式

2016(1-3月) 码农类General 硕士 全职@Snapchat - 网上海投 - 技术电面  | Other | fresh grad应届毕业生

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?Sign Up 注册获取更多干货

x
自己写了一个bigInt, 觉得不是特别好, 而且不知道怎么处理负数, 有没有大神可以贴一个代码? 拜谢!
chengguo201063 发表于 2016-2-15 06:52:00 | 显示全部楼层
co-ask how to process neg values
回复 支持 反对

使用道具 举报

panlong222 发表于 2016-2-17 23:04:08 | 显示全部楼层
请问楼主,能把题目完整说下嘛~多谢啦!
回复 支持 反对

使用道具 举报

bentison90 发表于 2016-3-10 13:11:42 | 显示全部楼层
自己写的一个,可以处理fraction的,只有加法,大家指正!


class BigInt{
   
public:
    string s;
    . 1point3acres
    BigInt(string str): s(str){}
   
    BigInt add(BigInt& num) {. Waral 博客有更多文章,
        string num1 = s;-google 1point3acres
        string num2 = num.s;
        
        if(num1.find('.') != -1 || num2.find('.') != -1) {
            if(num1.find('.') == -1) num1 += '.';.留学论坛-一亩-三分地
            if(num2.find('.') == -1) num2 += '.';
            int fLen1 = num1.size() - num1.find('.')-1;
            int fLen2 = num2.size() - num2.find('.')-1;
            padding(num1, max(fLen1, fLen2) - fLen1);. Waral 博客有更多文章,
            padding(num2, max(fLen1, fLen2) - fLen2);.本文原创自1point3acres论坛
        }
        
        
        reverse(num1.begin(), num1.end());
        reverse(num2.begin(), num2.end());
        string res;
        int alen = num1.size();
. 1point 3acres 论坛        int blen = num2.size();
        int carry = 0;. 一亩-三分-地,独家发布
        for(int i = 0, j = 0; i < alen || j < blen; i++, j++) {
            if(num1[i] == '.') {
                res += '.';
                continue;
            }
            int val1 = i < alen ? num1[i] - '0' : 0;
            int val2 = j < blen ? num2[j] - '0' : 0;-google 1point3acres
            int sum = val2 + val1 + carry;
            res += char((sum % 10) + '0');
            carry = sum / 10;
        }
        if(carry) res += "1";. more info on 1point3acres
        reverse(res.begin(), res.end());
        
        return BigInt(res);
    }-google 1point3acres
    void padding(string& num, int len) {
        if(len <= 0) return;
        string pad(len, '0');
        num += pad;
    }
   
};
回复 支持 反对

使用道具 举报

wanghwadad 发表于 2016-9-24 05:41:24 | 显示全部楼层
楼主能不能说一下具体的题啊,多谢
回复 支持 反对

使用道具 举报

本版积分规则

提醒:发帖可以选择内容隐藏,部分板块支持匿名发帖。请认真读完以下全部说明:

■隐藏内容方法: [hide=200]你想要隐藏的内容比如面经[/hide]
■意思是:用户积分低于200则看不到被隐藏的内容
■可以自行设置积分值,不建议太高(200以上太多人看不到),也不建议太低(那就没必要隐藏了)
■建议只隐藏关键内容,比如具体的面试题目、涉及隐私的信息,大部分内容没必要隐藏。
■微信/QQ/电子邮件等,为防止将来被骚扰甚至人肉,以论坛私信方式发给对方最安全。
■匿名发帖的板块和方法:http://www.1point3acres.com/bbs/thread-405991-1-1.html

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明

custom counter

GMT+8, 2018-5-26 01:05

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

快速回复 返回顶部 返回列表