华为"128为大整数相加"机试题
最近正直春招,偶尔接触到了华为的这道大整数相加的测试题,在网上找了一个算法,然后自己尝试进行了优化,最后也对memmove()函数效率有了进一步把握.
#include <time.h>
#include <iostream>
using namespace std;
#define MAX_LENGTH 128
void Add(const char *pszOperand1, const char *pszOperand2, char *pszResult); //互联网上原始代码
void Add2(const char *pszOperand1, const char *pszOperand2, char *pszResult, size_t len ); //优化后的代码
int main()
{
char szOperand1[MAX_LENGTH + 1], szOperand2[MAX_LENGTH + 1], szResult[MAX_LENGTH + 2];
cin >> szOperand1 >> szOperand2;
clock_t startTime = clock();
for ( int i = 0; i < 100000000; ++i ) //原始代码测试
{
Add(szOperand1, szOperand2, szResult);
}
clock_t endTime = clock();
cout << szOperand1 << " + " << szOperand2 << " = " << szResult << endl;
cout << "Total time = " << endTime - startTime << endl; //132725ms
startTime = clock();
for ( int i = 0; i < 100000000; ++i ) //优化后代码测试
{
Add2( szOperand1, szOperand2, szResult, MAX_LENGTH+2 );
}
endTime = clock();
cout << szOperand1 << " + " << szOperand2 << " = " << szResult << endl;
cout << "Total time = " << endTime - startTime << endl; //84287ms
//总结:Add2()函数比Add()函数在使用了memmove()优化后效率提升了36.28%,而空间节省了40%。
return 0;
}
void Add(const char *pszOperand1, const char *pszOperand2, char *pszResult)
{
short iResult[MAX_LENGTH + 1];
short iCarry = 0;
int i = (int) strlen(pszOperand1) - 1;
int j = (int) strlen(pszOperand2) - 1;
int k = MAX_LENGTH + 1;
while (i >= 0 || j >= 0)
{
k--;
iResult[k] = 0;
if (i >= 0)
iResult[k] += pszOperand1[i--] - '0';
if (j >= 0)
iResult[k] += pszOperand2[j--] - '0';
iResult[k] += iCarry;
if (iResult[k] >= 10)
{
iResult[k] -= 10;
iCarry = 1;
}
else
iCarry = 0;
}
if (iCarry == 1)
iResult[--k] = 1;
i = 0;
for (; k <= MAX_LENGTH; k++, i++)
pszResult[i] = iResult[k] + '0';
pszResult[i] = '\0';
}
void Add2(const char *pszOperand1, const char *pszOperand2, char *pszResult, size_t len )
{
size_t i = strlen( pszOperand1 );
size_t j = strlen( pszOperand2 );
if ( len < (max(i, j) +2 ) )
return;
size_t k = len;
pszResult[--k] = '\0';
short temp = 0;
short curso = 0;
while ( i > 0 || j > 0 )
{
temp = curso;
if ( i > 0 )
temp += pszOperand1[--i] - '0';
if ( j > 0 )
temp += pszOperand2[--j] - '0';
if ( temp > 10 )
{
pszResult[--k] = temp - 10 + '0';
curso = 1;
}
else
{
pszResult[--k] = temp + '0';
curso = 0;
}
}
memmove( pszResult, pszResult + k, len - k );
}
测试用例:被加数与加数都是下面的120位整数
123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890
测试环境:
编译器 :vs 2005
操作系统:windows7 64 bit
处理器 :英特尔 Pentium(奔腾) G860 @ 3.00GHz 双核
内存 :4 GB ( 金士顿 DDR3 1600MHz )
总结:Add2()函数比Add()函数在使用了memmove()优化后效率提升了36.28%,而空间节省了40%。
华为"128为大整数相加"机试题的更多相关文章
- HDU 1002 A + B Problem II(大整数相加)
A + B Problem II Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u De ...
- SOJ 1002/1003/1004 大整数相加/相乘/相除
三个题目分别考察大整数相加相乘相除运算.如果按照传统算法是取一个长数组,之后进行模拟或者FFT来进行运算.但是相对繁琐. 后来昨天的青岛区域赛网赛1001,用到了JAVA的BigDecimal,于是反 ...
- HDOJ-1002 A + B Problem II (非负大整数相加)
http://acm.hdu.edu.cn/showproblem.php?pid=1002 输入的数都是正整数,比较好处理,注意进位. //非负大整数加法 # include <stdio.h ...
- 1024 Palindromic Number int_string转换 大整数相加
A number that will be the same when it is written forwards or backwards is known as a Palindromic Nu ...
- 大整数相加 a+b 的c语言实现
终于来到我所期盼的高精度整数相加的题目了.这个题很经典,也算是一个很好的算法入门题吧. 如果是java的话,系统类库已经内置了BigInteger类,直接调用就可以很轻易地解决了.但是学习c的编写也是 ...
- C++ string 实现大整数相加减
随意两个大整数的加减算法.可自己主动推断正负号.代码例如以下: #include <iostream> #include <vector> #include <cstri ...
- Javascript实现大整数加法
记得之前面试还被问到过用两个字符串实现两个大整数相加,当时还特别好奇好好的整数相加,为什么要用字符串去执行.哈哈,感觉当时自己还是很无知的,面试官肯定特别的无奈.今天在刷算法的时候,无意中看到了为什么 ...
- 华为OJ机试题目:两个大整数相乘(纯C语言实现两个大整数相乘,两种方法实现大数相乘)
题目描述: 输出两个不超过100位的大整数的乘积. 输入: 输入两个大整数,如1234567 123 输出: 输出乘积,如:151851741 样例输入: 1234567 123 样例输出: 1518 ...
- 九度oj题目&吉大考研11年机试题全解
九度oj题目(吉大考研11年机试题全解) 吉大考研机试2011年题目: 题目一(jobdu1105:字符串的反码). http://ac.jobdu.com/problem.php?pid=11 ...
随机推荐
- 集群(cluster)原理(转)
1.什么是集群 集群(cluster)就是一组计算机,他们作为整体向用户提供一组网络资源.这些单个的计算机系统就是集群的节点(node).一个理想的集群是,用户从不会意识到集群系统底层的节点,在他 ...
- windows系统常见端口和木马默认使用端口
dos命令netstat比较好用,能比较全的看到自己开放的端口及状态一般我用netstat -a端口:0服务:Reserved说明:通常用于分析操作系统.这一方法能够工作是因为在一些系统中“0”是无效 ...
- 入門必學NO.1 Android 初學特訓班(第四版) 目錄
第 01 章 敲開 Android 的開發大門工欲善其事,必先利其器,要學習 Android 應用程式,先取得功能強大的開發工具,就可讓學習事半功倍. 1.1 Android 是啥米?1.2 建構 A ...
- ie9,10 uploadify cleanUp bug
起因:ie多次加载uploadify3.2版本这个组件的时候,出现了SCRIPT5007: 缺少对象. From:http://blog.163.com/xiangfei209@126/blog/s ...
- “更高效率:标准化+简约风+移动化”--K2 BPM老客户交流会
主题:工作流主数据标准化和移动工作流带来的企业沟通建设机会 嘉宾:李瑞延(盛大网络IT总监) 公司管理需要更好的工作流 -为决策提供依据 通过对各级业务公司各类流程数据的获取与分析,为管理决策提供必要 ...
- CCNA 6.9
page 201 show ip route Correction(05-4) Basic configuration of R1: enable configure terminal ...
- CPU是怎么制造的
大概的过程就是,先选一堆好沙子(纯净的沙子),初步加工一般在沿海,然而都是初加工,因为技术不行,所以一般用比较污染环境的方法加工大99.9%纯度的硅,然后低价卖给国外企业,用高精尖技术加工到99.99 ...
- mybatis 的 resulttype 和resultMap
resultType适合返回值比较简单的,比如一个数据类型,或者一个对象.比如对象的情况,是将表的列名和对象的属性一一对应的. 但是resultType无法处理返回值比较复杂的,特别是连接查询,需要用 ...
- C#线程状态简析
在C# 语言世界中,当我们创建一个新的子线程,该线程状态为unstarted, 子线程开始之后,子线程状态为Running,IsAlive 为true: 线程响应 Thread.Start 并开始运行 ...
- 一点点webservice的小知识
怕自己忘了记录下来好了 在web.config中要配置自己要调用的webservice的地址 在自己controller中获取web.config中配置的地址 SystemManager.Config ...