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