編程題
假定輸入的字符串中只包含字母和*號(hào)。請(qǐng)編寫(xiě)函數(shù)fun,它的功能是:除了字符串前導(dǎo)的*號(hào)之外,將串中其它*號(hào)全部刪除。在編寫(xiě)函數(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)中填入你編寫(xiě)的若干語(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';
}
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |