解题思路:直接看注释吧
注意事项:
参考代码:
#include<string.h> #include<stdio.h> int fun(char *a) { int i=0;//代表目前数组的下标 while(*(a+i)=='*')//跳过前面的*号,遇到其他的就退出那么数组的下标就标到了那个不是*号的位上 { i++; } while(*(a+i)!='\0')//遍历数组 { if(*(a+i)=='*')//遇到*就把后面的全部往前移一格覆盖掉 { for(int j=i;*(a+j)!='\0';j++)//我这里把\0也向前移了 { *(a+j)=*(a+(j+1)); } i--;//注意这里会出现多个*号连续的情况所以要停下来继续检测这个新移上来的是不是*号 } i++;//如果没遇到*号就标到下一个,遇到了上面i--就刚好抵消继续检查当前 } return 0; } int main() { char s[81]; gets(s); fun(s); puts(s); return 0; }
0.0分
1 人评分
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:644 |
WU-图形输出 (C++代码)浏览:836 |
wu-淘淘的名单 (C++代码)浏览:1532 |
A+B for Input-Output Practice (C语言代码)浏览:505 |
1048题解(读入回车问题)浏览:628 |
蓝桥杯历届试题-翻硬币 (C++代码)浏览:953 |
用筛法求之N内的素数。 (C语言代码)浏览:595 |
大神老白 (C语言代码)浏览:637 |
整数平均值 (C语言代码)浏览:856 |
C语言程序设计教程(第三版)课后习题12.5 (C语言代码)浏览:799 |