ImageVerifierCode 换一换
格式:DOCX , 页数:14 ,大小:18.13KB ,
资源ID:28424362      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/28424362.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(上机填空题7376.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

上机填空题7376.docx

1、上机填空题737673题目: 请补充main函数,该函数的功能是:输出一个N*N矩阵,要求非对角线上的元素赋值0,对角线元素赋值1。 注意:部分源程序如blank.c给出。 仅在横线上填入所编写的若干表达式或语句,勿改动函数中的其它任何内容。 #include #define N 10 main() int bbNN; int i,j,n; clrscr(); printf( nInput n:n); scanf(%d,&n); for(i=0;in;i+) for(j=0;jn;j+) _1_; if( i=j) bbij=_2_; if(_3_) bbij=1; printf( n* th

2、e result * n); for(i=0;in;i+) printf( nn); for(j=0;jn;j+) printf(%4d,bbij); printf(n); 74题目: 给定程序中,函数fun的功能是:将形参std所指结构体数组中年龄最大者的数据作为函数值返回,并在main函数中输出。 注意:部分源程序如blank.c给出。 请勿改动主函数main和其他函数中的任何内容,仅在fun函数的横线上填入所编写的若干表达式或语句。 #include typedef struct char name10; int age; STD; STD fun(STD std, int n) STD

3、 max; int i; max= _1_; for(i=1; in; i+) if(max.age_2_) max=stdi; return max; main( ) STD std5=aaa,17,bbb,16,ccc,18,ddd,17,eee,15 ; STD max; max=fun(std,5); printf(nThe result: n); printf(nName : %s, Age : %dn, _3_,max.age); 75题目: 请补充main函数,该函数的功能是:求1+2!+3!+N!的和。 例如,1+2!+3!+5!的和为153。 注意:部分源程序如blank.c

4、给出。 仅在横线上填入所编写的若干表达式或语句,勿改动函数中的其它任何内容。 #include main( ) int i,n; long s=0,t=1; clrscr(); printf(nInput n:n); scanf(%d,_1_); for(i=1;i=n;i+) t=_2_; s=_3_; printf(1!+2!+3!.+%d!=%ldn,n,s); 76题目: 请补充fun函数,该函数的功能是:把字符串str中的字符按字符的ASCII码降序排列,处理后的字符串仍然保存在原串中,字符串及其长度作为函数参数传入。 例如,如果输入abcde,则输出edcba。 注意:部分源程序如

5、blank.c给出。 请勿改动主函数main和其他函数中的任何内容,仅在fun函数的横线上填入所编写的若干表达式或语句。 #include #define N 80 void fun(char s,int n) int i,j; char ch; for(i=0;in;i+) for(j=_1_;jn;j+) if(sisj) ch=sj; _2_; si=ch; main() int i=0,strlen=0; char strN; clrscr(); printf(nInput a string:n); gets(str); while(stri!=0) strlen+; i+; fun(

6、str,strlen); printf(n* display string *n); puts(str); 最优质的服务,最合适的价位,最满意服务等着你,淘宝网! 解答73分析: 题目要求输出一个N*N矩阵,要求非对角线上的元素赋值0,对角线元素赋值1。此题关键的地方就是要正确表达对角线元素的下标。对角线存在正对角线和反对角线两个,例如以下矩阵,正对角线元素是:1、7、13、19、25。反对角线元素是:5、9、13、17、21。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 正对角线元素下标的特征是行、列值相

7、等,例如19的行列下标都是3,注意表示矩阵的二维数组行、列下标都是从0开始的。反对角线元素下标的特征是总行数-行下标-1就等于列数。例如17的行下标为3,列下标为1,即5-3-1=1。 程序注解如下: #include #define N 10 main() int bbNN; int i,j,n; /* clrscr函数的作用是清屏,清除输出窗口中所有已经显示的内容 */ clrscr(); printf( nInput n:n); scanf(%d,&n); /* 逐个处理每一行 */ for(i=0;in;i+) /* 处理第i行的所有列 */ for(j=0;jn;j+) /* 先将元

8、素统统先作为非对角线元素设置为0 */ bbij=0; /* 正对角线元素设置为1 */ if( i=j) bbij=1; /* 反对角线元素设置为1 */ if(j=n-1-i) bbij=1; printf( n* the result * n); /* 输出处理之后的矩阵 */ for(i=0;in;i+) printf( nn); for(j=0;jn;j+) printf(%4d,bbij); printf(n); 74分析: 题目要求在fun函数中将形参std所指结构体数组中年龄最大者的数据作为函数值返回。为了实现以上要求,程序约定max变量存放数组中年龄最大者的数据,然后先将st

9、d数组的第一个元素std0,也就是*std先放入max变量。然后使用for循环将std数组中每一个元素的age成员与max变量的age成员进行比较大小,如果比max变量的age成员更加大,则将这个更大的数组元素覆盖max变量中的原有值。当循环结束的时候,max变量中就保存了题目要求寻找的std所指结构体数组中年龄最大者的数据。最后将max返回即可。 程序注解如下: #include typedef struct char name10; int age; STD; STD fun(STD std, int n) STD max; int i; /* max= *std语句将std第一个元素放入

10、max */ /* 因为std是数组名,数组名在C语言中就是指针名 */ /* 通过取指针内容的运算符(*)可以取得std0的值,所以*std就是std0 */ max= *std; /* 逐个检查std数组中每一个元素的age成员与max中age成员的大小 */ for(i=1; in; i+) if(max.agestdi.age) /* 将更大的值保存在max中,确保max保存了年龄最大值 */ max=stdi; return max; main( ) STD std5=aaa,17,bbb,16,ccc,18,ddd,17,eee,15 ; STD max; max=fun(std,

11、5); printf(nThe result: n); printf(nName : %s, Age : %dn, max.name,max.age); 75分析: 题目要求在fun函数中求1+2!+3!+N!的和。为了实现题目要求,我们必须知道n!即n的阶乘的计算公式,即n!的计算公式是n!=n*(n-1)*(n-2)*(n-3)*3*2*1。 程序首先设置t初始值为1,将t作为每一项阶乘的乘积。设置s初始值为0,将s作为整个1+2!+3!+N!的总和。 然后计算t=t*i=1*1=1,然后计算s=s+t = 0+1=1,这样就将1+2!+3!+N!中的第一项1计算完成。 然后计算t=t*i

12、=1*2=2,然后计算s=s+t=1+2=3,这样就将1+2!+3!+N!中的第二项2!计算完成。 然后计算t=t*i=2*3=6,然后计算s=s+t=3+6=9,这样就将1+2!+3!+N!中的第二项3!计算完成。 反复进行以上计算过程。最终s的值就是1+2!+3!+N!的总和。 程序注解如下: #include main( ) int i,n; long s=0,t=1; /* clrscr函数的作用是清屏,清除输出窗口中所有已经显示的内容 */ clrscr(); printf(nInput n:n); /* 输入n变量的值 */ scanf(%d,&n); /* 从1至n进行计算每一项

13、阶乘t和合计值s */ for(i=1;ib表达式比较的是d和b两个字符的ASCII码,由于d和b的ASCII码分别是100和98,所以d的ASCII码大于b的ASCII码,所以db表达式成立。 为了实现题目要求,程序使用了以下思路: 假设s数组中存在内容baedc,首先寻找baedc中ASCII码最大的字符放入第一个字符位置。方法是使用循环将b字符即s0作为最大值分别与后面其余字符比较大小,如果发现ASCII码比s0更大的字符则交换该字符和s0的位置。当循环结束的时候,s0存放的位置必然是s数组所有字符中ASCII码最大的字符。这一次循环结束的时候,s数组中的内容为:eabdc。 然后从s1

14、开始重复以上过程,将s1作为ASCII码最大的字符。然后使用循环将s1分别与后面其余字符比较大小,如果发现ASCII码比s1更大的字符则交换该字符和s1的位置。当循环结束的时候,s1存放的位置必然是s数组除了s0以外所有字符中ASCII码最大的字符。这一次循环结束的时候,s数组中的内容为:edabc。 重复以上过程直至整个字符串数组s都按降序排列。 程序注解如下: #include #define N 80 void fun(char s,int n) int i,j; char ch; /* 逐个确定每一段的ASCII码最大的字符 */ for(i=0;in;i+) /* 找出第i个字符至最

15、后一个字符之间ASCII码最大的字符放入si */ for(j=i;jn;j+) /* 如果发现比作为最大值的si更大的字符则交换两者 */ /* 确保si存放si至最后一个字符之间ASCII码最大的字符 */ if(sisj) /* 以下三句作用是交换sj与si */ /* 将sj预先保存在ch中,防止丢失数据 */ ch=sj; /* 将si移动到sj中进行保存 */ sj=si; /* 将预先保存在ch中的原来sj的值移动到si进行保存 */ si=ch; main() int i=0,strlen=0; char strN; /* clrscr函数的作用是清屏,清除输出窗口中所有已经显示的内容 */ clrscr(); printf(nInput a string:n); /* gets函数的作用是接收键盘输入的字符串,将其放入str参数中 */ gets(str); /* 统计str字符串的长度,将其放入i变量中 */ while(stri!=0) strlen+; i+; fun(str,strlen); printf(n* display string *n); /* puts函数的作用是输出str参数的内容 */ puts(str);

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1