全国计算机等级考试题库二级C操作题100套(第16套)
第16套:
給定程序中,函數fun的功能是:求出形參ss所指字符串數組中最長字符串的長度,將其余字符串右邊用字符*補齊,使其與最長的字符串等長。ss所指字符串數組中共有M個字符串,且串長<N。
請在程序的下劃線處填入正確的內容并把下劃線刪除,使程序得出正確的結果。
注意:源程序存放在考生文件夾下的BLANK1.C中。
不得增行或刪行,也不得更改程序的結構!
給定源程序:
#include <stdio.h> #include <string.h> #define M 5 #define N 20 void fun(char (*ss)[N]) { int i, j, n, len=0; for(i=0; i<M; i++) { len=strlen(ss[i]); if(i==0) n=len; if(len>n)n=len; } for(i=0; i<M; i++) { n=strlen(___1___); for(j=0; j<len-n; j++) ss[i][ ___2___]='*'; ss[i][n+j+ ___3___]='\0'; } } main() { char ss[M][N]={"shanghai","guangzhou","beijing","tianjing","cchongqing"}; int i; printf("The original strings are :\n"); for(i=0; i<M; i++) printf("%s\n",ss[i]); printf("\n"); fun(ss); printf("The result is :\n"); for(i=0; i<M; i++) printf("%s\n",ss[i]); }解題思路:
第一處:利用for循環語句取當前字符串的長度,所以應填:ss[i]。
第二處:在字符串的右邊填字符*,其開始位置是n+j,其中n是該字符串本身的長度,j是循環控制變量,所以應填:n+j。
第三處:字符串處理結束應置字符串結束符,其位置是n+j+1,所以應填:1。
給定程序MODI1.C中 fun 函數的功能是:將p所指字符串中每個單詞的最后一個字母改成大寫。(這里的“單詞”是指由空格隔開的字符串)。
例如, 若輸入
“I am a student to take the examination.”,則應輸出 “I aM A studenT tO takE thE examination.”。
請修改程序中的錯誤之處, 使它能得出正確的結果。
注意: 不要改動 main 函數, 不得刪行, 也不得更改程序的結構!
給定源程序:
#include <ctype.h> #include <stdio.h> void fun( char *p ) { int k = 0; for( ; *p; p++ ) if( k ) { if( p == ' ' ) { k = 0; * (p-1) = toupper( *( p - 1 ) ) } } else k = 1; } main() { char chrstr[64]; int d ; printf( "\nPlease enter an English sentence within 63 letters: "); gets(chrstr); d=strlen(chrstr) ; chrstr[d] = ' ' ; chrstr[d+1] = 0 ; printf("\n\nBefore changing:\n %s", chrstr); fun(chrstr); printf("\nAfter changing:\n %s", chrstr); }解題思路:
第一處:關鍵字int錯寫成INT。
第二處:該行括號沒有配對,所以只要加上一個右括號即可。
請編寫函數fun, 對長度為7個字符的字符串, 除首、尾字符外,將其余5個字符按ASCII碼降序排列。
例如,原來的字符串為 CEAedca,排序后輸出為 CedcEAa 。
注意: 部分源程序在文件PROG1.C中。
請勿改動主函數main和其它函數中的任何內容, 僅在函數fun的花括號中填入你編寫的若干語句。
給定源程序:
#include <stdio.h> #include <ctype.h> #include <string.h> int fun(char *s,int num) { } main() { char s[10]; printf("輸入7個字符的字符串:"); gets(s); fun(s,7); printf("\n%s",s); NONO(); }解題思路:
本題是考察考生如何對字符串中的字符按降序進行排序。給出的程序是使用雙重for循環以及冒泡法進行排序的,結果仍存放在原先的字符串上。
參考答案:
int fun(char *s,int num) { char ch ; int i, j ; for(i = 1 ; i < 6 ; i++) for(j = i + 1 ; j < 6 ; j++) { if(*(s + i) < *(s + j)) { ch = *(s + j) ; *(s + j) = *(s +i) ; *(s + i) = ch ; } } }總結
以上是生活随笔為你收集整理的全国计算机等级考试题库二级C操作题100套(第16套)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Windows安装SSH连接远程服务器以
- 下一篇: 视觉SLAM十四讲第七讲