填空題
給定程序中,函數(shù)fun的功能是:在形參ss所指字符串?dāng)?shù)組中,刪除所有串長(zhǎng)超過(guò)k的字符串,函數(shù)返回所剩字符串的個(gè)數(shù)。ss所指字符串?dāng)?shù)組中共有N個(gè)字符串,且串長(zhǎng)小于M。
請(qǐng)?jiān)诔绦虻南聞澗€處填入正確的內(nèi)容并把下劃線刪除, 使程序得出正確的結(jié)果。
注意:源程序存放在考生文件夾下的BLANK1.C中。
不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
給定源程序:
#include
#include
#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
f=fun(x,7);
printf("The string witch length is less than or equal to 7 :\n");
for(i=0; i
}
解題思路:
本題是根據(jù)給定的字符串?dāng)?shù)組中刪除串長(zhǎng)大于某個(gè)值的字符串。
第一處:利用for循環(huán),從幾個(gè)字符串中進(jìn)行查找,程序中已經(jīng)給定了N個(gè)字符串,所以應(yīng)填:N。
第二處:串長(zhǎng)由形參k來(lái)傳遞,所以應(yīng)填:k。
第三處:如果字符串ss[i]的串長(zhǎng)小于k,則該字符串仍存在原字符串?dāng)?shù)組中,位置由變量j 來(lái)控制,所以應(yīng)填:ss[i]。
改錯(cuò)題
給定程序MODI1.C中函數(shù)fun的功能是:逐個(gè)比較p、q所指兩個(gè)字符串對(duì)應(yīng)位置中的字符,把ASCII值大或相等的字符依次存放到c所指數(shù)組中,形成一個(gè)新的字符串。
例如,若主函數(shù)中a字符串為:aBCDeFgH,
主函數(shù)中b字符串為:ABcd,
則c中的字符串應(yīng)為:aBcdeFgH。
請(qǐng)改正程序中的錯(cuò)誤,使它能得出正確結(jié)果。
注意:不要改動(dòng)main函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)。
給定源程序:
#include
#include
void fun(char *p ,char *q, char *c)
{
int k = 1;
while( *p != *q )
{ if( *p<*q ) c[k]=*q;
else c[k]=*p;
if(*p) p++;
if(*q) q++;
k++;
}
}
main()
{ char a[10]="aBCDeFgH", b[10]="ABcd", c[80]={'\0'};
fun(a,b,c);
printf("The string a: "); puts(a);
printf("The string b: "); puts(b);
printf("The result : "); puts(c);
}
解題思路:
第一處: 存放字符串初始位置也是從0開始存放的,由于k是控制c字符串的位置值,所以k值應(yīng)為0。
第二處: 判斷兩個(gè)字符串中是否有字符串結(jié)束符產(chǎn)生,所以應(yīng)改為:while( *p || *q ),
而不是兩字符串中對(duì)應(yīng)位置的值不相等。
編程題
假定輸入的字符串中只包含字母和*號(hào)。請(qǐng)編寫函數(shù)fun,它的功能是:除了字符串前導(dǎo)的*號(hào)之外,將串中其它*號(hào)全部刪除。在編寫函數(shù)時(shí),不得使用C語(yǔ)言提供
的字符串函數(shù)。函數(shù)fun中給出的語(yǔ)句僅供參考。
例如,字符串中的內(nèi)容為:****A*BC*DEF*G*******,刪除后, 字符串中的內(nèi)容應(yīng)當(dāng)是:****ABCDEFG。
注意: 部分源程序在文件PROG1.C文件中。
請(qǐng)勿改動(dòng)主函數(shù)main和其它函數(shù)中的任何內(nèi)容,僅在函數(shù)fun的花括號(hào)中填入你編寫的若干語(yǔ)句。
給定源程序:
#include
void fun( char *a )
{
int i=0,k;
while(a[i]=='*') i++;
k=i+1;
while(a[i]!='\0') /* 以下程序段實(shí)現(xiàn)非*字符前移 */
{
} www.Examda.CoM
a[i+1]='\0';
}
main()
{ char s[81];
printf("Enter a string:\n");gets(s);
fun( s );
printf("The string after deleted:\n");puts(s);
NONO();
}
解題思路:
本題是考察字符串的操作。
1. 使用while循環(huán)語(yǔ)句求出字符串前導(dǎo)*號(hào)的個(gè)數(shù)。
2. 使用while循環(huán)語(yǔ)句判斷a[i]是否是字符串結(jié)束符標(biāo)志,如果不是字符串結(jié)束標(biāo)志,則再判斷是否是字符*號(hào),如果不是*號(hào),則把a(bǔ)[i]字符存入a[k]中,如果是*號(hào)則跳過(guò)該*號(hào),直至字符串結(jié)束為止。
參考答案:
void fun( char *a )
{
int i=0,k;
while(a[i]=='*') i++;
k=i;
while(a[i]!='\0') /* 以下程序段實(shí)現(xiàn)非*字符前移 */
{
if(a[i] != '*') a[k++]=a[i];
i++;
}
a[k]='\0';
}
給定程序中,函數(shù)fun的功能是:在形參ss所指字符串?dāng)?shù)組中,刪除所有串長(zhǎng)超過(guò)k的字符串,函數(shù)返回所剩字符串的個(gè)數(shù)。ss所指字符串?dāng)?shù)組中共有N個(gè)字符串,且串長(zhǎng)小于M。
請(qǐng)?jiān)诔绦虻南聞澗€處填入正確的內(nèi)容并把下劃線刪除, 使程序得出正確的結(jié)果。
注意:源程序存放在考生文件夾下的BLANK1.C中。
不得增行或刪行,也不得更改程序的結(jié)構(gòu)!
給定源程序:
#include
#include
#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
f=fun(x,7);
printf("The string witch length is less than or equal to 7 :\n");
for(i=0; i
}
解題思路:
本題是根據(jù)給定的字符串?dāng)?shù)組中刪除串長(zhǎng)大于某個(gè)值的字符串。
第一處:利用for循環(huán),從幾個(gè)字符串中進(jìn)行查找,程序中已經(jīng)給定了N個(gè)字符串,所以應(yīng)填:N。
第二處:串長(zhǎng)由形參k來(lái)傳遞,所以應(yīng)填:k。
第三處:如果字符串ss[i]的串長(zhǎng)小于k,則該字符串仍存在原字符串?dāng)?shù)組中,位置由變量j 來(lái)控制,所以應(yīng)填:ss[i]。
改錯(cuò)題
給定程序MODI1.C中函數(shù)fun的功能是:逐個(gè)比較p、q所指兩個(gè)字符串對(duì)應(yīng)位置中的字符,把ASCII值大或相等的字符依次存放到c所指數(shù)組中,形成一個(gè)新的字符串。
例如,若主函數(shù)中a字符串為:aBCDeFgH,
主函數(shù)中b字符串為:ABcd,
則c中的字符串應(yīng)為:aBcdeFgH。
請(qǐng)改正程序中的錯(cuò)誤,使它能得出正確結(jié)果。
注意:不要改動(dòng)main函數(shù),不得增行或刪行,也不得更改程序的結(jié)構(gòu)。
給定源程序:
#include
#include
void fun(char *p ,char *q, char *c)
{
int k = 1;
while( *p != *q )
{ if( *p<*q ) c[k]=*q;
else c[k]=*p;
if(*p) p++;
if(*q) q++;
k++;
}
}
main()
{ char a[10]="aBCDeFgH", b[10]="ABcd", c[80]={'\0'};
fun(a,b,c);
printf("The string a: "); puts(a);
printf("The string b: "); puts(b);
printf("The result : "); puts(c);
}
解題思路:
第一處: 存放字符串初始位置也是從0開始存放的,由于k是控制c字符串的位置值,所以k值應(yīng)為0。
第二處: 判斷兩個(gè)字符串中是否有字符串結(jié)束符產(chǎn)生,所以應(yīng)改為:while( *p || *q ),
而不是兩字符串中對(duì)應(yīng)位置的值不相等。
編程題
假定輸入的字符串中只包含字母和*號(hào)。請(qǐng)編寫函數(shù)fun,它的功能是:除了字符串前導(dǎo)的*號(hào)之外,將串中其它*號(hào)全部刪除。在編寫函數(shù)時(shí),不得使用C語(yǔ)言提供
的字符串函數(shù)。函數(shù)fun中給出的語(yǔ)句僅供參考。
例如,字符串中的內(nèi)容為:****A*BC*DEF*G*******,刪除后, 字符串中的內(nèi)容應(yīng)當(dāng)是:****ABCDEFG。
注意: 部分源程序在文件PROG1.C文件中。
請(qǐng)勿改動(dòng)主函數(shù)main和其它函數(shù)中的任何內(nèi)容,僅在函數(shù)fun的花括號(hào)中填入你編寫的若干語(yǔ)句。
給定源程序:
#include
void fun( char *a )
{
int i=0,k;
while(a[i]=='*') i++;
k=i+1;
while(a[i]!='\0') /* 以下程序段實(shí)現(xiàn)非*字符前移 */
{
} www.Examda.CoM
a[i+1]='\0';
}
main()
{ char s[81];
printf("Enter a string:\n");gets(s);
fun( s );
printf("The string after deleted:\n");puts(s);
NONO();
}
解題思路:
本題是考察字符串的操作。
1. 使用while循環(huán)語(yǔ)句求出字符串前導(dǎo)*號(hào)的個(gè)數(shù)。
2. 使用while循環(huán)語(yǔ)句判斷a[i]是否是字符串結(jié)束符標(biāo)志,如果不是字符串結(jié)束標(biāo)志,則再判斷是否是字符*號(hào),如果不是*號(hào),則把a(bǔ)[i]字符存入a[k]中,如果是*號(hào)則跳過(guò)該*號(hào),直至字符串結(jié)束為止。
參考答案:
void fun( char *a )
{
int i=0,k;
while(a[i]=='*') i++;
k=i;
while(a[i]!='\0') /* 以下程序段實(shí)現(xiàn)非*字符前移 */
{
if(a[i] != '*') a[k++]=a[i];
i++;
}
a[k]='\0';
}