11004512实验报告 (2500字).doc

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
11004512实验报告 (2500字)

验报告 (2500字) 第一题R010E 1.问题描述:将一个正整数n(长整型)输出成“千分位”形式,即从个位数起,每三位之间加一个逗号,例如,将7654321输出成7,654,321。 2.课题分析:如果数小于一千,则不用转换,如果大于一千则要,也就是一个数除以一千,取整,在整数后面加一个逗号后再写上余数。考察的C语言知识是关于取整取余及字符,判断等内容的运用。 3.数据结构的设计: char c=#39;,#39;; // 千分位的符号 int n, //输入的数 int a[100]//存储用千分位表示的数 if(nlt;1000) // 比较输入的数是否大于一千 printf(quot;%dquot;,n); //如果输入的数小于一千,则直接输出 else { for(i=0;ngt;=1000;i++) { a[i]=n%1000; //取余 n/=1000; //取整数 j=i+1; } a[j]=n; for(i=j;igt;0;i--)// 循环运行直到条件不符合 { printf(quot;%d%cquot;,a[i],c); }printf(quot;%dquot;,a[0]); //输出 } 4.处理结构的设计: 5.源程序: #includelt;stdio.hgt; void main() { char c=#39;,#39;; int n,i=0,j=0,a[100]; printf(quot;请输入一个正整数n:\nquot;); scanf(quot;%dquot;,amp;n); if(nlt;1000) printf(quot;%dquot;,n); //如果输入的数小于一千,则直接输出 else { for(i=0;ngt;=1000;i++) { a[i]=n%1000; //取余 n/=1000; //取整数 j=i+1; } a[j]=n; for(i=j;igt;0;i--) { printf(quot;%d%cquot;,a[i],c); }printf(quot;%dquot;,a[0]); } printf(quot;\nquot;); } 6.调试记录: 第二题P007M 1. 问题描述:编制不同数制间的转换程序。要求提供输入输出界面,当输 完一个任意十进制数字,程序能自动将其转化为另外的数制表示的值,包括二进制、八进制和十六进制,其中转化用算法实现,而不是用printf函数显示。 2.课题分析:将十进制数转换为其他进制的数,其算法是以将被换为的进制数作为除数,从给出的数起依次作除求余,直至整除后结果为零,然后将运 算中所得的余数按倒序排列即得到数制转换后所得的数。 在定义数组时需要注意到无符号长整型数的取值范围,提供足够但有效地数组长度。 转换为二进制的数与转换为八进制的数的算法基本一致,即依次记下求余所得,并判断整除后是否为零决定是否继续运算,而转换为十六进制的数时前十个为数字表示,而后面六个数为用大写的’A’~’F’表示。 3.数据结构的设计:unsigned long a,temp;//存储所要转换的数和整除后的数 char b[64];//存储二进制数的数组 char o[21];// 存储八进制数的数组 char h[16];// 存储十六进制数的数组 在此,所定义的三个数组的长度即分别有效地考虑到无符号长整型数的 取值范围 b[i]=temp%2+#39;0#39;;//求余;强制类型转换为实数 temp/=2;//整除运算 在此需根据temp的值判断是否运算完毕 while(igt;=0) {printf(quot;%cquot;,b[i]); i--;//从后向前依次输出while(tempamp;amp;ilt;16) { int x=temp%16; if(xlt;10) h[i]=x+#39;0#39;; else h[i]=x-10+#39;A#39;;//前十个为数字

文档评论(0)

170****0532 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8015033021000003

1亿VIP精品文档

相关文档