| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1148 人关注过本帖
标题:[求助]实现高精度整数运算(已经实现加减乘除)求(求模、与、或、非、异或等运 ...
只看楼主 加入收藏
喝茶的小k
Rank: 1
等 级:新手上路
帖 子:87
专家分:0
注 册:2006-7-27
收藏
 问题点数:0 回复次数:1 
[求助]实现高精度整数运算(已经实现加减乘除)求(求模、与、或、非、异或等运算)

[求助]实现高精度整数运算(已经实现加减乘除)
求(求模、与、或、非、异或等运算)
//实现高精度加减乘除运算

#include <iostream.h>
#include <stdio.h>
#include <string.h>
#include <math.h>

void main()
{
char str1[200],str2[200],str3[100000];
cin>>str1;
cin>>str2;
//cout<<str1<<str2;
//cout<<str3;
int num1=strlen(str1);
int num2=strlen(str2);
int num3=0;
//cout<<num1<<" "<<num2<<endl;
if(num1>=num2)
num3=num1;
else
num3=num2;
//cout<<num3<<endl;
/*char *p1,*p2,*p3;
p1=str1;
p2=str2;
p3=str3;*/
int k=0;
//k表示进位值
for(int i=num3;i>0;i--)
{
str3[i]=(str2[num2-1]-48)+(str1[num1-1]-48)+k;
k=str3[i]/10;
//cout<<k<<endl;
str3[i]=str3[i]%10;
//printf("%d\n",str3[i]);
if(num2>1)
{
num2=num2-1;
}
else
{
str2[0]=48;
}


if(num1>1)
{
num1=num1-1;
}
else
{
str1[0]=48;
}

}
str3[0]=k;
for( i=1-k;i<=num3;i++)
{
printf("%d",str3[i]);
}
cout<<endl;
}

搜索更多相关主题的帖子: 加减乘除 整数 高精度 运算 include 
2006-12-26 16:11
卧龙孔明
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:59
帖 子:3872
专家分:684
注 册:2006-10-13
收藏
得分:0 
与、或、非、异与加法类似,而且更好判断,先将各个位数的末尾找到,然后进行每一位数的与、或、非、异运算,将结果保存.

但求模不好算,与高精度除高精度的除法类似

My Blog: www.aiexp.info
虽然我的路是从这里开始的,但是这里不再是乐土.感谢曾经影响过,引导过,帮助过我的董凯,飞燕,leeco,starwing,Rockcarry,soft_wind等等等等.别了,BCCN.
2006-12-27 20:37
快速回复:[求助]实现高精度整数运算(已经实现加减乘除)求(求模、与、或、非、异 ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.036536 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved