博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Hulu笔试编程题--大整数加法
阅读量:4205 次
发布时间:2019-05-26

本文共 2277 字,大约阅读时间需要 7 分钟。

周五参加了Hulu的笔试,70分钟的时间题量很大,自己准备得还是非常不充分,前面十道选择题就花去了40分钟时间,后面5道填空题只好蒙了。就这样时间还是很不够,考的题目都是比较基础的算法、数据结构,再加简单的推理。还是自身的原因。后面的算法题也很基础,大整数加法(可以比较下大整数乘法)。之前做过,不过由于时间原因,这次该注意的地方都没注意到。很是遗憾,这里是回来之后写的代码。提醒自己好好复习,不要浪费时间。

#include 
using namespace std;int main(){ //string s1="3213124324131254356342652624624"; string s2="4"; string s1="9999999999999999999999999999999999999999999999"; if(s1.length() > s2.length()) { string tmp = s1; s1 = s2; s2 = tmp; } string result(s2.length(), '0'); int advance = 0; int i, j; for(i = s2.length() - 1, j = s1.length() - 1; j >= 0; --i, --j) { result[i] =((s1[j] - '0') + (s2[i] - '0') + advance) % 10 + '0'; advance = ((s1[j] - '0') + (s2[i] - '0') + advance) / 10; } while(advance && i != -1)//trick 考虑到两者位数相等的情况,必须判断i是否为-1. { result[i] = ((s2[i] - '0') + advance) % 10 + '0'; advance = ((s2[i] - '0') + advance) / 10; --i; } if(i != -1) { while(i != -1) { result[i] = s2[i]; --i; } } else { result.insert(result.begin(),advance + '0'); } cout<
<
注:为了后面分析简单,如果s1比s2位数多,则两者交换,保证s2总是位数多的。不知道这样做是不是必需的,反正有额外消耗。

         另外,结果字符串另外用了存储空间,这个也是比较偷懒的做法,需要额外空间消耗。

#include 
#include
using namespace std;string add(string left, string right){ int advance = 0; string res; int i, j; for(i = left.length() - 1, j = right.length() - 1; i >= 0 && j >= 0; --i, --j) { int sum = left[i] - '0' + right[j] - '0' + advance; advance = sum / 10; sum %= 10; res.insert(0, 1, '0' + sum); } if(i > 0) { for(int j = i; j >= 0; --j) { int sum = left[j] - '0' + advance; advance = sum / 10; sum %= 10; res.insert(0, 1, '0' + sum); } } else if(j > 0) { for(int i = j; i >= 0; --i) { int sum = right[i] - '0' + advance; advance = sum / 10; sum %= 10; res.insert(0, 1, '0' + sum); } } if(advance != 0) res.insert(0, 1, '0' + advance); return res;}int main(){ string res; string left = "12346", right ="4"; res = add(left, right); cout<
<

转载地址:http://wxxli.baihongyu.com/

你可能感兴趣的文章
LoadRunner脚本评审Checklist
查看>>
在LoadRunner中设置HTTP请求time-out的时间
查看>>
在LoadRunner脚本中实现随机ThinkTime
查看>>
LoadRunner9.51中文帮助手册
查看>>
RPT录制问题
查看>>
RPT8.0
查看>>
RPT8.1新特性
查看>>
LoadRunner测试AJAX
查看>>
LoadRunner测试GWT
查看>>
负载测试项目成功的5个关键要素
查看>>
LoadRunner性能测试培训大纲
查看>>
LoadRunner测试J2ME的Socket程序
查看>>
《QTP自动化测试实践》要出第二版了!
查看>>
用LoadRunner开发开心网外挂
查看>>
QTP测试.NET控件CheckedListBox
查看>>
使用QTP的.NET插件扩展技术测试ComponentOne的ToolBar控件
查看>>
用上帝之眼进行自动化测试
查看>>
为LoadRunner写一个lr_save_float函数
查看>>
PrefTest工作室全新力作-《性能测试与调优实战》课程视频即将上线
查看>>
质量度量分析与测试技术 培训大纲
查看>>