无限大整数相加算法的C语言源代码
忙里偷闲,终于完成了无限大整数相加算法的C语言代码,无限大整数相加算法的算法分析在这里。
500位的加法运行1000次,不打印结果的情况下耗时0.036秒,打印结果的情况下耗时16.285秒。
下面是源码:
#include <stdio.h>
#include <stdlib.h>
#include<string.h>
#include <time.h> #define MAXNUM 1000000000000000000
/*
存储数据用的结构
long int型指针(Number)指向一个long int 数组,索引值最底的位,
为10进制数的最低18位。依次类推。
int型数值(Length)为数组的长度。
因为数组长度受int型最大值的限制,所以这个算法也不能真正实现“无限”。
*/
struct BigInt{
long long* Number;
int Length;
}; void PrintBigInt(BigInt* bigNumber); long long pow(int x, int y); BigInt* MakeBigIntFromString(char* bigIntString); void DeleteBigInt(BigInt* bigNumber); BigInt* Add2BigInt(BigInt* n1, BigInt* n2); void main(){ char* numberStr = "99999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999\0";
char* numberStr2 = "99999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999\0";
BigInt* bn = MakeBigIntFromString(numberStr);
BigInt* bn2 = MakeBigIntFromString(numberStr2);
double tstart, tend, tcost;
tstart = clock();
PrintBigInt(bn);
PrintBigInt(bn2);
for (int i = ; i < ; i++){
BigInt* result = Add2BigInt(bn, bn2);
//PrintBigInt(result);
DeleteBigInt(result);
}
DeleteBigInt(bn);
DeleteBigInt(bn2);
tend = clock();
tcost = (double)(tend - tstart) / CLOCKS_PER_SEC;
printf("%lf\n", tcost);
} BigInt* Add2BigInt(BigInt* n1, BigInt* n2){ int maxLength = n1->Length;
if (maxLength < n2->Length){
maxLength = n2->Length;
} /*
加法只可能产生1位的进位,所以,只需要创建一个和最大长度相同的。
*/
BigInt* nOut = (BigInt*)malloc(sizeof(BigInt));
nOut->Length = maxLength;
nOut->Number = (long long*)malloc(sizeof(long long)* nOut->Length);
for (int i = ; i < nOut->Length; i++){
nOut->Number[i] = ;
}
for (int i = ; i < nOut->Length; i++){
if (n1->Length > i){
nOut->Number[i] += n1->Number[i];
}
if (n2->Length > i){
nOut->Number[i] += n2->Number[i];
} /*
处理进位。最高位不需要处理。
*/
if (i != (nOut->Length - )){
if (nOut->Number[i] >= MAXNUM){
nOut->Number[i] -= MAXNUM;
nOut->Number[i + ] = ;
}
}
} return nOut; } /*
从高到低显示数值
不考虑单个long long数据超出18位的情况。
*/
void PrintBigInt(BigInt* bigNumber){
if (bigNumber == NULL){
return;
}
if (bigNumber->Length < ){
return;
}
int length = bigNumber->Length - ;
for (int i = length; i >= ; i--){
if (i != length){
if (bigNumber->Number[i] == ){
printf("");
}
else{
printf("%018lld", bigNumber->Number[i]);
}
}
else{
if ((*bigNumber).Number[i] != ){
printf("%lld", bigNumber->Number[i]);
}
}
}
printf("\n"); } /*
把字符串表示的数值格式化为BigInt型的结构
字符串结束位置用\0表示。
*/
BigInt* MakeBigIntFromString(char* bigIntString){
/*获取字符串长度*/
int cLength = strlen(bigIntString);
BigInt* outBigInt = (BigInt*)malloc(sizeof(BigInt));
if (cLength % != ){
outBigInt->Length = cLength / + ;
}
else{
outBigInt->Length = cLength / ;
}
if (outBigInt->Length == ){
outBigInt->Length == ;
outBigInt->Number = (long long *)malloc(sizeof(long long));
outBigInt->Number[] = ; return outBigInt;
}
outBigInt->Number = (long long *)malloc(sizeof(long long)* outBigInt->Length);
for (int i = ; i < outBigInt->Length; i++){
outBigInt->Number[i] = ;
} int powNum = ;
int numPos = ;
for (int i = cLength - ; i >= ; i--){
powNum = (cLength - - i) % ;
numPos = (cLength - - i) / ;
outBigInt->Number[numPos] += (bigIntString[i] - ) * pow(, powNum);
} return outBigInt;
} /*
简单的幂函数
x y 都必须为正整数
*/
long long pow(int x, int y){
if (x == || x < || y < ){
return ;
}
if (x == || y == ){
return ;
}
long long outNum = x; for (int i = ; i < y; i++){
outNum = outNum * x;
} return outNum;
} void DeleteBigInt(BigInt* bigNumber){
if (bigNumber != NULL){
if (bigNumber->Number != NULL){
free(bigNumber->Number);
}
free(bigNumber);
}
}
无限大整数相加算法的C语言源代码的更多相关文章
- 大整数相加 a+b 的c语言实现
终于来到我所期盼的高精度整数相加的题目了.这个题很经典,也算是一个很好的算法入门题吧. 如果是java的话,系统类库已经内置了BigInteger类,直接调用就可以很轻易地解决了.但是学习c的编写也是 ...
- 【算法】C语言趣味程序设计编程百例精解
C语言趣味程序设计编程百例精解 C/C++语言经典.实用.趣味程序设计编程百例精解(1) https://wenku.baidu.com/view/b9f683c08bd63186bcebbc3c. ...
- 【转载】常见十大经典排序算法及C语言实现【附动图图解】
原文链接:https://www.cnblogs.com/onepixel/p/7674659.html 注意: 原文中的算法实现都是基于JS,本文全部修改为C实现,并且统一排序接口,另外增加了一些描 ...
- 华为"128为大整数相加"机试题
最近正直春招,偶尔接触到了华为的这道大整数相加的测试题,在网上找了一个算法,然后自己尝试进行了优化,最后也对memmove()函数效率有了进一步把握. #include <time.h># ...
- 1164: 零起点学算法71——C语言合法标识符(存在问题)
1164: 零起点学算法71——C语言合法标识符 Time Limit: 1 Sec Memory Limit: 64 MB 64bit IO Format: %lldSubmitted: 10 ...
- SOJ 1002/1003/1004 大整数相加/相乘/相除
三个题目分别考察大整数相加相乘相除运算.如果按照传统算法是取一个长数组,之后进行模拟或者FFT来进行运算.但是相对繁琐. 后来昨天的青岛区域赛网赛1001,用到了JAVA的BigDecimal,于是反 ...
- 排序算法总结(C语言版)
排序算法总结(C语言版) 1. 插入排序 1.1 直接插入排序 1.2 Shell排序 2. 交换排序 2.1 冒泡排序 2.2 快速排序 3. 选择 ...
- 魔方阵算法及C语言实现
1 魔方阵概念 填充的,每一行.每一列.对角线之和均相等的方阵,阶数n = 3,4,5….魔方阵也称为幻方阵. 例如三阶魔方阵为: 魔方阵有什么的规律呢? 魔方阵分为奇幻方和偶幻方.而偶幻方又分为是4 ...
- 一个UUID生成算法的C语言实现 --- WIN32版本 .
一个UUID生成算法的C语言实现——WIN32版本 cheungmine 2007-9-16 根据定义,UUID(Universally Unique IDentifier,也称GUID)在时 ...
随机推荐
- Java数组的内存管理
Java数组的内存管理 Java语言是典型的静态语言,因此Java的数组是静态的,即当数组被初始化之后,该数组的长度是不可变的.Java程序中的数组必须经初始化才能使用.所谓初始化,就是当数组对象的元 ...
- 第3组UI组件:AdapterView及其子类
1 AdapterView类简介 1.1 AdapterView组件是一组重要的组件,AdapterView本身是一个抽线类,实际使用更多的都是Adapter相关子类,AdapterView具有如下特 ...
- cocos2d-x中,简单html富文本显示
作者:HU 转载请注明,原文链接:http://www.cnblogs.com/xioapingguo/p/4037414.html 虽然自从cocos2d-x更新到3.0后,使用freetype, ...
- POJ 2003 Hire and Fire (Tree)
题目:Hire and Fire 题目翻译成数据结构就是:建树,加结点,删除结点,打印结点.只有删除结点稍微复杂点,因为删除设计掉树的调整. 首先要考虑树怎么存储才能使解题更顺手. 1.我们要存储每个 ...
- C#-获取datagriview选中行中某一列的值
获取选中行中某一列的值: int index = dg_Product.CurrentRow.Index; //取得选中行的索引 txt_ProductId.Text = dg_Product.Row ...
- TQ210裸机编程(2)——LED流水灯
两个文件start.S和led.c start.S .global _start @声明一个全局的标号 _start: bl main ...
- 【shell】while read line 与for循环的区别
http://m.blog.itpub.net/22664653/viewspace-1175858/
- php一些技术要点连接地址
http基本认证: http://www.php.net/manual/zh/features.http-auth.php
- eclipse中不能找到dubbo.xsd解决方法
使用dubbo时遇到问题: org.xml.sax.SAXParseException: schema_reference.4: Failed to read schema document 'htt ...
- h5拖放-ff的bug
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...