| 查看: 1660 | 回复: 18 | |||
| 本帖产生 2 个 程序强帖 ,点击这里进行查看 | |||
[交流]
【求助】那位达人给我个大数相乘的算法吧 谢谢了
|
|||
| 看了一个大数相乘的算法,运行了一下,但是不对,想看看高手的代码,先谢啦 |
» 猜你喜欢
生物学学硕,一志愿湖南大学,初试成绩338
已经有6人回复
321求调剂
已经有7人回复
343求调剂
已经有4人回复
305求调剂
已经有3人回复
本科新能源科学与工程,一志愿华理能动285求调剂
已经有6人回复
332求调剂
已经有3人回复
学硕274求调剂
已经有8人回复
压国家一区线,求导师收留,有恩必谢!
已经有7人回复
081200-11408-276学硕求调剂
已经有4人回复
22408 359分调剂
已经有4人回复
» 本主题相关价值贴推荐,对您同样有帮助:
Pt/C催化剂活性不够,求催化达人解疑
已经有6人回复
金币请教达人一求方差的问题,十分着急,要考试了!
已经有16人回复
请教有经验的有机达人——过柱分离问题
已经有10人回复
请教数学达人关于残差的问题
已经有3人回复
求助环保达人,固体废弃物重金属浸出到底用什么方法?
已经有8人回复
求达人翻译一段德语,有机合成方面的,急~~~
已经有1人回复
请达人帮忙看一下,编辑如下的拒稿理由能否debate一下
已经有6人回复
【讨论】请教达人:混合表面活性剂的浓溶液为什么很容易会结皮?
已经有7人回复
【求助】关于数据拟合,请教数学达人
已经有4人回复
【English】英语口语和听力如何去学习,求达人给个意见?
已经有10人回复
【求助】向各位前辈达人请教户口问题
已经有10人回复
» 抢金币啦!回帖就可以得到:
【招聘】温州医科大学/附属医院/瓯江实验室李校堃院士团队诚聘博士后和科研人员
+1/191
【招聘】温州医科大学/附属医院/瓯江实验室李校堃院士团队诚聘博士后和科研人员
+1/190
2026年赣南师范大学 电子科学与技术专业(学硕)+ 电子信息工程(专硕)接收调剂学生
+1/189
天津科技大学生物质功能材料研究团队 硕士招生
+1/97
南昌航空大学材料学院教授/博导团队招收调剂研究生
+1/95
上海高校招收化学,材料,环境,化工等专业基础的同学攻读硕士研究生
+1/82
坐标广州,征女友
+2/50
五邑大学(江门-利物浦公共卫生研究所)招收药学、生物医药专业调剂生
+1/45
南通大学国家级人才团队招收卫生检验、医学检验相关方向调剂研究生
+2/44
国家工程物理交叉科学研究中心招收凝聚态物理及相关专业硕士研究生一名
+1/42
国家双一流高校-国家级青年人才课题组博士招生
+2/32
【博士招生】南京林业大学车辆工程课题组招收26年9月入学“申请-考核制”博士研究生
+1/12
西安工程大学环境与化学工程学院能源环境催化与先进材料课题组招生
+1/9
国家双一流高校-国家级青年人才课题组博士招生
+1/7
欢迎调剂报考
+1/6
南京林业大学化学工程学院柏惺峰课题组招收硕士研究生1名
+1/6
【博士招生】广东工业大学国家优青课题组招收2026年环境方向博士生
+1/5
三峡大学材化学院磷硅精细化工课题组招收化学类、材料类、材料与化工类硕士
+1/5
【博士招生】上海交通大学陈倩栎课题组招收2026年申请-考核博士生1名(能源材料方向)
+1/4
上海师范大学有机化学专业研究生招生
+1/2
3楼2011-04-02 17:02:13
8楼2011-04-02 21:05:56
|
#include #include using namespace std; int *multi(int *num1,int size1,int *num2,int size2) {//返回位数为size1+size2 int size=size1+size2; int *ret=new int [size]; int i=0; memset(ret,0,sizeof(int)*size); for(i=0;i int k=i; for(int j=0;j ret[k++]+=num2*num1[j]; } } for(i=0;i if(ret>=10) { ret[i+1]+=ret/10; ret=ret%10; } } return ret; } int main() { /*int m,n,num1[100],num2[100]; cout<<"输入第一个数的位数"< cout<<"输入第一个数"< cin>>num1; } cout<<"输入第二个数位数"< cout<<"输入第二个数"< cin>>num2; } */ int num1[]={3,2}; int num2[]={1,1}; int *ret=multi(num1,2 ,num2,2 ); for(int i=3 ;i>=0;i--) { cout< } delete [] ret;//内存释放 cin.get(); return 0; } 这是那个代码 去上课了 现在才回复 不好意思啊 我试了那两个 是反着的 而且也不太懂 想看看高手的易读些的代码 谢谢 |
9楼2011-04-02 21:16:03
|
#include #include using namespace std; int *multi(int *num1,int size1,int *num2,int size2) {//返回位数为size1+size2 int size=size1+size2; int *ret=new int [size]; int i=0; memset(ret,0,sizeof(int)*size); for(i=0;i int k=i; for(int j=0;j ret[k++]+=num2*num1[j]; } } for(i=0;i if(ret>=10) { ret[i+1]+=ret/10; ret=ret%10; } } return ret; } int main() { /*int m,n,num1[100],num2[100]; cout<<"输入第一个数的位数"< cout<<"输入第一个数"< cin>>num1; } cout<<"输入第二个数位数"< cout<<"输入第二个数"< cin>>num2; } */ int num1[]={3,2}; int num2[]={1,1}; int *ret=multi(num1,2 ,num2,2 ); for(int i=3 ;i>=0;i--) { cout< delete [] ret;//内存释放 cin.get(); return 0; } 这是那个代码 去上课了 现在才回复 不好意思啊 我试了那两个 是反着的 而且也不太懂 想看看高手的易读些的代码 谢谢 |
10楼2011-04-02 21:16:59
|
#include #include using namespace std; int *multi(int *num1,int size1,int *num2,int size2) {//返回位数为size1+size2 int size=size1+size2; int *ret=new int [size]; int i=0; memset(ret,0,sizeof(int)*size); for(i=0;i int k=i; for(int j=0;j ret[k++]+=num2*num1[j]; } } for(i=0;i if(ret>=10) { ret[i+1]+=ret/10; ret=ret%10; } } return ret; } int main() { /*int m,n,num1[100],num2[100]; cout<<"输入第一个数的位数"< cout<<"输入第一个数"< cin>>num1; } cout<<"输入第二个数位数"< cout<<"输入第二个数"< cin>>num2; } */ int num1[]={3,2}; int num2[]={1,1}; int *ret=multi(num1,2 ,num2,2 ); for(int i=3 ;i>=0;i--) { cout< delete [] ret;//内存释放 cin.get(); return 0; } 这是那个代码 去上课了 现在才回复 不好意思啊 我试了那两个 是反着的 而且也不太懂 想看看高手的易读些的代码 谢谢 |
11楼2011-04-02 21:17:16
|
#include #include using namespace std; int *multi(int *num1,int size1,int *num2,int size2) {//返回位数为size1+size2 int size=size1+size2; int *ret=new int [size]; int i=0; memset(ret,0,sizeof(int)*size); for(i=0;i int k=i; for(int j=0;j ret[k++]+=num2*num1[j]; } } for(i=0;i if(ret>=10) { ret[i+1]+=ret/10; ret=ret%10; } } return ret; } int main() { /*int m,n,num1[100],num2[100]; cout<<"输入第一个数的位数"< cout<<"输入第一个数"< cin>>num1; } cout<<"输入第二个数位数"< cout<<"输入第二个数"< cin>>num2; } */ int num1[]={3,2}; int num2[]={1,1}; int *ret=multi(num1,2 ,num2,2 ); for(int i=3 ;i>=0;i--) { cout< delete [] ret;//内存释放 cin.get(); return 0; } 这是那个代码 去上课了 现在才回复 不好意思啊 我试了那两个 是反着的 而且也不太懂 想看看高手的易读些的代码 谢谢 |
12楼2011-04-02 21:18:16
14楼2011-04-03 10:57:30
★ ★ ★ ★
青涩草(金币+1):谢谢参与
余泽成(金币+3, 程序强帖+1): 谢谢参与应助! 2011-05-13 21:23:05
青涩草(金币+1):谢谢参与
余泽成(金币+3, 程序强帖+1): 谢谢参与应助! 2011-05-13 21:23:05
|
#include #define N 10000 void main() { int a[N],n,k,i,j,m,flag=1;//flag代表位数 printf("请输入一个100以内的正数" ;scanf("%d",&n); for(i=1;i<=N;i++) a=0;//这个循环使得数组里的每一个元素初值都为0 a[1]=1;//为了便于累乘运算,特殊的将a[1]赋值为1 for(k=1;k<=n;k++)//大循环用于计算小于n的所有的数 { flag=1; for(i=1;i<=k;i++) { for(j=1;j<=flag;j++) a[j]*=i; for(j=1;j<=flag;j++) { if(a[j]>9)//从低位到高位判断是否大于9,如果大于,则进位 { for(m=1;m<=flag;m++) { if(a[flag]>9) flag++;//控制所求得的数的阶乘的位数 a[m+1]+=a[m]/10; a[m]=a[m]%10;//将数字分离到每一个数组元素里 } } } } printf("%d的阶乘的全部有效数字为",k); for(;flag>=1;flag--) printf("%d",a[flag]);//从高位往低位依次输出 printf("\n\n" ;for(i=1;i<=N;i++) a=0; a[1]=1;//每次运行以上步骤时都会改变数组a中的值,须再次赋值 } } |
16楼2011-05-12 20:36:13
17楼2011-05-12 21:34:38
18楼2011-05-13 08:36:52
19楼2011-05-13 09:00:53
简单回复
小飞—动力2楼
2011-04-02 17:00
回复
青涩草(金币+1):谢谢参与
2011-04-02 17:19
回复
青涩草(金币+1):谢谢参与
daijiash5楼
2011-04-02 20:36
回复
青涩草(金币+1):谢谢参与
太阳谷6楼
2011-04-02 20:37
回复
青涩草(金币+1):谢谢参与
祝福!
xlli1217楼
2011-04-02 20:51
回复
青涩草(金币+1):谢谢参与
lipearpear13楼
2011-04-02 21:24
回复
青涩草(金币+1):谢谢参与
tangyanxmc15楼
2011-04-03 11:14
回复
青涩草(金币+1):谢谢参与

祝福














回复此楼
;
这当然是可能的啦