為大家收集整理了《2013計(jì)算機(jī)二級(jí)C語(yǔ)言上機(jī)練習(xí)題及答案(16)》供大家參考,希望對(duì)大家有所幫助!??!
填空題
給定程序中,函數(shù)fun的功能是:求出形參ss所指字符串?dāng)?shù)組中最長(zhǎng)字符串的長(zhǎng)度,將其余字符串右邊用字符*補(bǔ)齊,使其與最長(zhǎng)的字符串等長(zhǎng)。ss所指字符串?dāng)?shù)組中共有M個(gè)字符串,且串長(zhǎng)
請(qǐng)?jiān)诔绦虻南聞澗€處填入正確的內(nèi)容并把下劃線刪除,使程序得出正確的結(jié)果。
注意:源程序存放在考生文件夾下的BLANK1.C中。
不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
給定源程序:
#include
#include
#define M 5
#define N 20
void fun(char (*ss)[N])
{ int i, j, n, len=0;
for(i=0; i
{ len=strlen(ss[i]);
if(i==0) n=len;
if(len>n)n=len;
}
for(i=0; i
n=strlen(___1___);
for(j=0; 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
printf("\n");
fun(ss);
printf("The result is :\n");
for(i=0; i
}
解題思路:
第一處:利用for循環(huán)語(yǔ)句取當(dāng)前字符串的長(zhǎng)度,所以應(yīng)填:ss[i]。
第二處:在字符串的右邊填字符*,其開始位置是n+j,其中n是該字符串本身的長(zhǎng)度,j是
循環(huán)控制變量,所以應(yīng)填:n+j。
第三處:字符串處理結(jié)束應(yīng)置字符串結(jié)束符,其位置是n+j+1,所以應(yīng)填:1。
改錯(cuò)題
給定程序MODI1.C中 fun 函數(shù)的功能是:將p所指字符串中每個(gè)單詞的最后一個(gè)字母改成大寫。(這里的“單詞”是指由空格隔開的字符串)。
例如, 若輸入
"I am a student to take the examination.",
則應(yīng)輸出 "I aM A studenT tO takE thE examination."。
請(qǐng)修改程序中的錯(cuò)誤之處, 使它能得出正確的結(jié)果。
注意: 不要改動(dòng) main 函數(shù), 不得刪行, 也不得更改程序的結(jié)構(gòu)!
給定源程序:
#include
#include
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);
}
解題思路:
第一處:關(guān)鍵字int錯(cuò)寫成INT。
第二處:該行括號(hào)沒有配對(duì),所以只要加上一個(gè)右括號(hào)即可。
編程題
請(qǐng)編寫函數(shù)fun, 對(duì)長(zhǎng)度為7個(gè)字符的字符串, 除首、尾字符外,將其余5個(gè)字符按ASCII碼降序排列。
例如,原來的字符串為 CEAedca,排序后輸出為 CedcEAa 。
注意: 部分源程序在文件PROG1.C中。
請(qǐng)勿改動(dòng)主函數(shù)main和其它函數(shù)中的任何內(nèi)容, 僅在函數(shù)fun的花括號(hào)中填入你編寫的若干語(yǔ)句。
給定源程序:
#include
#include
#include
int fun(char *s,int num)
{
}
main()
{
char s[10];
printf("輸入7個(gè)字符的字符串:");
gets(s);
fun(s,7);
printf("\n%s",s);
NONO();
}
解題思路:
本題是考察考生如何對(duì)字符串中的字符按降序進(jìn)行排序。給出的程序是使用雙重for循環(huán)以及冒泡法進(jìn)行排序的,結(jié)果仍存放在原先的字符串上。
參考答案:
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 ;
}
}
}
填空題
給定程序中,函數(shù)fun的功能是:求出形參ss所指字符串?dāng)?shù)組中最長(zhǎng)字符串的長(zhǎng)度,將其余字符串右邊用字符*補(bǔ)齊,使其與最長(zhǎng)的字符串等長(zhǎng)。ss所指字符串?dāng)?shù)組中共有M個(gè)字符串,且串長(zhǎng)
請(qǐng)?jiān)诔绦虻南聞澗€處填入正確的內(nèi)容并把下劃線刪除,使程序得出正確的結(jié)果。
注意:源程序存放在考生文件夾下的BLANK1.C中。
不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
給定源程序:
#include
#include
#define M 5
#define N 20
void fun(char (*ss)[N])
{ int i, j, n, len=0;
for(i=0; i
{ len=strlen(ss[i]);
if(i==0) n=len;
if(len>n)n=len;
}
for(i=0; i
n=strlen(___1___);
for(j=0; 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
printf("\n");
fun(ss);
printf("The result is :\n");
for(i=0; i
}
解題思路:
第一處:利用for循環(huán)語(yǔ)句取當(dāng)前字符串的長(zhǎng)度,所以應(yīng)填:ss[i]。
第二處:在字符串的右邊填字符*,其開始位置是n+j,其中n是該字符串本身的長(zhǎng)度,j是
循環(huán)控制變量,所以應(yīng)填:n+j。
第三處:字符串處理結(jié)束應(yīng)置字符串結(jié)束符,其位置是n+j+1,所以應(yīng)填:1。
改錯(cuò)題
給定程序MODI1.C中 fun 函數(shù)的功能是:將p所指字符串中每個(gè)單詞的最后一個(gè)字母改成大寫。(這里的“單詞”是指由空格隔開的字符串)。
例如, 若輸入
"I am a student to take the examination.",
則應(yīng)輸出 "I aM A studenT tO takE thE examination."。
請(qǐng)修改程序中的錯(cuò)誤之處, 使它能得出正確的結(jié)果。
注意: 不要改動(dòng) main 函數(shù), 不得刪行, 也不得更改程序的結(jié)構(gòu)!
給定源程序:
#include
#include
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);
}
解題思路:
第一處:關(guān)鍵字int錯(cuò)寫成INT。
第二處:該行括號(hào)沒有配對(duì),所以只要加上一個(gè)右括號(hào)即可。
編程題
請(qǐng)編寫函數(shù)fun, 對(duì)長(zhǎng)度為7個(gè)字符的字符串, 除首、尾字符外,將其余5個(gè)字符按ASCII碼降序排列。
例如,原來的字符串為 CEAedca,排序后輸出為 CedcEAa 。
注意: 部分源程序在文件PROG1.C中。
請(qǐng)勿改動(dòng)主函數(shù)main和其它函數(shù)中的任何內(nèi)容, 僅在函數(shù)fun的花括號(hào)中填入你編寫的若干語(yǔ)句。
給定源程序:
#include
#include
#include
int fun(char *s,int num)
{
}
main()
{
char s[10];
printf("輸入7個(gè)字符的字符串:");
gets(s);
fun(s,7);
printf("\n%s",s);
NONO();
}
解題思路:
本題是考察考生如何對(duì)字符串中的字符按降序進(jìn)行排序。給出的程序是使用雙重for循環(huán)以及冒泡法進(jìn)行排序的,結(jié)果仍存放在原先的字符串上。
參考答案:
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 ;
}
}
}