C语言编程练习题

上传人:xt****7 文档编号:134275473 上传时间:2022-08-12 格式:DOC 页数:9 大小:49.01KB
收藏 版权申诉 举报 下载
C语言编程练习题_第1页
第1页 / 共9页
C语言编程练习题_第2页
第2页 / 共9页
C语言编程练习题_第3页
第3页 / 共9页
资源描述:

《C语言编程练习题》由会员分享,可在线阅读,更多相关《C语言编程练习题(9页珍藏版)》请在装配图网上搜索。

1、本练习假设:整数int为4字节,运行环境为VC 一、整数位数有关的问题1、输入一个整数,判断它是几位数?#include void main()int a,n=0;scanf(%d,&a);答案在后面思路:如何数出位数?while(a0)a/=10;n+;printf(%dn,n);扩展:编制一个函数,参数为整数,返回该整数的位数。答案在后面int digits(int a)int n=0;while(a0)a/=10;n+;return n;2、编制一函数,得到一个整数的某一位的数字。int digit(int a,int n) /*返回:整数a的倒数第n位数,n从1开始*/答案在后面思路:

2、如何将倒数第n位用一个表达式取出?不能!转变成怎样后就能?while(n1)a/=10;n-;return a%10;测试函数的例子:#include int digit(int a,int n);void main()int a,n,d;scanf(%d%d,&a,&n);d=digit(a,n);printf(%dn,d);二、关于整数的几个题目1、输入两个正整数m和n,求其最大公约数和最小公倍数。算法分析:采用辗转相除法,先求出最大公约数d,然后求最小公倍数c=m*n/d。辗转相除法:余数=大数%小数,然后将小数和余数再作辗转相除。#include void main()int m,n,

3、a,b,d,c;scanf(%d,%d,&m,&n);if(mn)a=m;b=n; /*保证ab*/else a=n;b=m;while(d=a%b)0) /*每次循环都测试余数是否为0*/a=b;b=d;d=b; /*得到最大公约数*/c=m*n/d; /*得到最小公倍数*/printf(最大公约数是%dn最小公倍数是%dn,d,c);拓展:编出求最大公约数的函数。int mcd(int a,int b)int d,t;if(ab*/while(d=a%b)0) /*每次循环都测试余数是否为0*/a=b;b=d;return b; /*得到最大公约数*/测试上述函数:#include int

4、 mcd(int a,int b);void main()int m,n,d,c;scanf(%d,%d,&m,&n);d=mcd(m,n);c=m*n/d;printf(最大公约数是%dn最小公倍数是%dn,d,c);2、求出所有的水仙花数。水仙花数是一个三位数,其各位数字的立方和等于该数。例如153=13+53+33。#include void main()int s,a,b,c;for(s=100;s=999;s+)a=s%10; b=s/10%10;c=s/100; /*分解出每一位*/if(a*a*a+b*b*b+c*c*c=s)printf(%dn,s);按位循环:#include

5、 void main()int s,a,b,c;for(a=0;a=9;a+)for(b=0;b=9;b+)for(c=1;c=9;c+)s=c*100+b*10+a;if(a*a*a+b*b*b+c*c*c=s)printf(%dn,s);类似地:可以求出100以内的勾股数,如32+42=52。三、关于数组的几个题目求2100的精确值。参考:#include void main()double s=1.0;int i;for(i=1;i=100;i+)s*=2;printf(%fn,s);运行结果:后面十多位全是0,因此是近似值。如何求精确值呢?(关键是如何保存每一位)#include vo

6、id main()答案在后面int s100=1; /*初始化第一位为0,其它每一位为0*/int i,j,m=0; /*m指示最高位为sm*/for(i=1;i=100;i+)for(j=0;j=m;j+)sj*=2;for(j=0;j9) /*第j位需要进位*/sj+1+=sj/10;sj%=10;if(j+1m) m=j+1; /*最高位进位*/printf(2100 = );for(j=m;j=0;j-)printf(%d,sj);printf(n);运行结果:扩展问题:如何求出100!的精确值?缺陷:如果乘以一个很大的数如20亿,会使高一位与进位相加后溢出。四、大数运算用整数数组存放

7、每一位,最高位用-1存储,如12存为:a0=2,a1=1,a2=-1。1、输入和存储大数。编制一函数,将合法数字组成的字符串表示的大数按位拆分存储到整数数组中,最高位前存储-1。/*转换大数:将字符串c中的数字保存到整数数组a中,a最高位添加-1标志*/void LargeSet(char *c, int *a) char *p;for(p=c;*p!=0;p+); /*找到末尾作为最低位*/p-;for(;p=c;p-,a+)*a=*p-0;*a=-1;2、输出和获得数字串。编制一函数,将大数转换成字符串。/*转换大数:将大数a转换成字符串存入字符数组c中*/void LargeGet(ch

8、ar *c, int *a) int *p;for(p=a;*p=0;p+);p-;for(;p=a;c+,p-)*c=*p+0;*c=0;3、大数相加。编制一函数,实现两个大数相加。void LargeAdd(int *a, int *b, int *s) /*大数相加:s=a+b*/int ka=0,kb=0;for(*s=0;ka=0|kb=0;s+)if(*a0) ka=1;if(*b9) *(s+1)=1;*s%=10;else *(s+1)=0;if(*s0) *(s+1)=-1;else if(*(s-1)0) *s=-1;else *(s-1)=-1;验证上面的函数:#incl

9、ude void LargeSet(char *a, int *s);void LargeGet(char *a, int *s);void LargeAdd(int *a, int *b, int *s);void main()int a100,b100,s100;char c100;scanf(%s,c);LargeSet(c,a);scanf(%s,c);LargeSet(c,b);LargeAdd(a,b,s);LargeGet(c,s);printf(sum is %sn,c);运行结果:扩展:可以编制大数相减、相乘、相除、乘方、开方等运算。有了这些运算,计算100!或2的100次方的精确值将变得很简单。

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!