全国计算机等级考试题库二级C操作题100套(第39套)
第39套:
給定程序中,函數fun的功能是:在形參ss所指字符串數組中,刪除所有串長超過k的字符串,函數返回所剩字符串的個數。ss所指字符串數組中共有N個字符串,且串長小于M。
請在程序的下劃線處填入正確的內容并把下劃線刪除, 使程序得出正確的結果。
注意:源程序存放在考生文件夾下的BLANK1.C中。
不得增行或刪行,也不得更改程序的結構!
給定源程序:
#include <stdio.h> #include <string.h> #define N 5 #define M 10 int fun(char (*ss)[M], int k) { int i,j=0,len; for(i=0; i< __1__ ; i++) { len=strlen(ss[i]); if(len<= __2__) strcpy(ss[j++],__3__); } return j; } main() { char x[N][M]={"Beijing","Shanghai","Tianjing","Nanjing","Wuhan"}; int i,f; printf("\nThe original string\n\n"); for(i=0;i<N;i++)puts(x[i]); printf("\n"); f=fun(x,7); printf("The string witch length is less than or equal to 7 :\n"); for(i=0; i<f; i++) puts(x[i]);printf("\n"); }解題思路:
本題是根據給定的字符串數組中刪除串長大于某個值的字符串。
第一處:利用for循環,從幾個字符串中進行查找,程序中已經給定了N個字符串,所以應填:N。
第二處:串長由形參k來傳遞,所以應填:k。
第三處:如果字符串ss[i]的串長小于k,則該字符串仍存在原字符串數組中,位置由變量j 來控制,所以應填:ss[i]。
給定程序MODI1.C中函數fun的功能是:逐個比較p、q所指兩個字符串對應位置中的字符,把ASCII值大或相等的字符依次存放到c所指數組中,形成一個新的字符串。
例如,若主函數中a字符串為:aBCDeFgH,
主函數中b字符串為:ABcd,
則c中的字符串應為:aBcdeFgH。
請改正程序中的錯誤,使它能得出正確結果。
注意:不要改動main函數,不得增行或刪行,也不得更改程序的結構。
給定源程序:
解題思路:
第一處: 存放字符串初始位置也是從0開始存放的,由于k是控制c字符串的位置值,所以k值應為0。
第二處: 判斷兩個字符串中是否有字符串結束符產生,所以應改為:while( *p || *q ),
而不是兩字符串中對應位置的值不相等。
假定輸入的字符串中只包含字母和號。請編寫函數fun,它的功能是:除了字符串前導的號之外,將串中其它號全部刪除。在編寫函數時,不得使用C語言提供
的字符串函數。函數fun中給出的語句僅供參考。
例如,字符串中的內容為:ABCDEFG*****,刪除后, 字符串中的內容應當是:****ABCDEFG。
注意: 部分源程序在文件PROG1.C文件中。
請勿改動主函數main和其它函數中的任何內容,僅在函數fun的花括號中填入你編寫的若干語句。
給定源程序:
解題思路:
本題是考察字符串的操作。
參考答案:
總結
以上是生活随笔為你收集整理的全国计算机等级考试题库二级C操作题100套(第39套)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: poj_3977 折半枚举
- 下一篇: 斗鱼视频sign签名逆向分析