編程題
假定輸入的字符串中只包含字母和*號(hào)。請(qǐng)編寫(xiě)函數(shù)fun,它的功能是:使字符串的前導(dǎo)*號(hào)不得多于n個(gè);若多于n個(gè),則刪除多余的*號(hào); 若少于或等于n個(gè),則什么也不做,字符串中間和尾部的*號(hào)不刪除。函數(shù)fun中給出的語(yǔ)句僅供參考。例如,字符串中的內(nèi)容為:*******A*BC*DEF*G****,若n的值為4,刪除后,
字符串中的內(nèi)容應(yīng)當(dāng)是:****A*BC*DEF*G****;若n的值為8,則字符串中的內(nèi)容仍
為:*******A*BC*DEF*G****。n的值在主函數(shù)中輸入。 在編寫(xiě)函數(shù)時(shí),不得使用C語(yǔ)言提供的字符串函數(shù)。
注意: 部分源程序在文件PROG1.C文件中。
請(qǐng)勿改動(dòng)主函數(shù)main和其它函數(shù)中的任何內(nèi)容,僅在函數(shù)fun的花括號(hào)中填入
你編寫(xiě)的若干語(yǔ)句。
給定源程序:
#include
void fun( char *a, int n )
{
int i=0,j,k=0;
while(a[k]=='*') k++; /* k為統(tǒng)計(jì)*字符個(gè)數(shù) */
if(k>n)
{
i=n;j=k;
/* 以下完成將下標(biāo)為k至串尾的字符前移k-n個(gè)位置 */
}
}
main()
{ char s[81]; int n;
printf("Enter a string:\n");gets(s);
printf("Enter n : ");scanf("%d",&n);
fun( s,n );
printf("The string after deleted:\n");puts(s);
NONO();
}
解題思路:
本題是考察字符串的操作。
利用for循環(huán)來(lái)判斷a[j]的字符是否是字符串結(jié)束符,如果不是字符串結(jié)束符,則把a(bǔ)[j]
的字符依次存放到a[i]。其中,變量i是n的初始值,變量j是字符串前導(dǎo)的*號(hào)數(shù)。
參考答案:
void fun( char *a, int n )
{
int i=0,j,k=0;
while(a[k]=='*') k++; /* k為統(tǒng)計(jì)*字符個(gè)數(shù) */
if(k>n)
{
i=n;j=k;
/* 以下完成將下標(biāo)為k至串尾的字符前移k-n個(gè)位置 */
for(; a[j] !=0 ; j++)
a[i++]=a[j];
a[i] = 0;
}
}
編輯推薦:
考試吧考后首發(fā)2013年9月計(jì)算機(jī)等級(jí)考試試題及答案
2013年計(jì)算機(jī)等級(jí)考試備考精華資料匯總
2013年9月計(jì)算機(jī)等級(jí)考試真題及答案解析專(zhuān)題北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |