一、算法描述
成都创新互联公司成立于2013年,先为乌翠等服务建站,乌翠等地企业,进行企业商务咨询服务。为乌翠企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。
逐个比较字符串source中的字符,若当前i位置的字符等于待删除字符ch,则i+1..len-1之间的子串整体前移;如此反复,直到所有待删除字符都找到并被删除为止。
二、操作过程
三、参考程序
#include stdio.h
#include string.h
/* 移除字符串source中的所有ch字符 */
void remove(char *source, char ch);
void main()
{
char source[1000];
char ch;
printf("请输入一个字符串:");
gets(source);
printf("请输入待删除字符:");
ch = getchar();
remove(source, ch);
printf("新的字符串:");
puts(source);
}
/* 移除字符串source中的所有ch字符 */
void remove(char *source, char ch)
{
int i, j;
int len = strlen(source);
for(i=0; source[i]!='\0'; i++)
{
if(source[i] == ch)
{
for(j=i+1; source[j]!='\0'; j++)
{
source[j-1] = source[j];
}
source[j-1] = '\0';
}
}
}
四、运行测试
请输入一个字符串:How are you?
请输入待删除字符:o
新的字符串:Hw are yu?
程序有误,修改如下:
#include stdio.h
#include string.h
void main(){
char sh[20];
gets(sh);
for(int i=0;i20;i++)
{
if(sh[i]='@')
{
printf("判断出有字符@\n");
break;
}
if(sh[i]='\0')printf("无字符@\n");
}
}
扩展资料:
数组的使用规则:
1.可以只给部分元素赋初值。当{ }中值的个数少于元素个数时,只给前面部分元素赋值。例如:static int a[10]={0,1,2,3,4};表示只给a[0]~a[4]5个元素赋值,而后5个元素自动赋0值。
2.只能给元素逐个赋值,不能给数组整体赋值。例如给十个元素全部赋1值,只能写为:static int a[10]={1,1,1,1,1,1,1,1,1,1};而不能写为:static int a[10]=1;请注意:在C、C#语言中是这样,但并非在所有涉及数组的地方都这样,数据库是从1开始。
3.如不给可初始化的数组赋初值,则全部元素均为0值。
4.如给全部元素赋值,则在数组说明中, 可以不给出数组元素的个数。例如:static int a[5]={1,2,3,4,5};可写为:static int a[]={1,2,3,4,5};动态赋值可以在程序执行过程中,对数组作动态赋值。这时可用循环语句配合scanf函数逐个对数组元素赋值。
参考资料:
百度百科-数组
1、打开文件,遍历文件内容然后一个一个匹配查找并替换,最后再重新写入文件当中。
2、例程:
#include
int main()
{
file *fp;
char filename[100];
printf("请输入文件名:\n");
gets(filename);
fp=fopen(filename,"r");
char c,x,flag=0;
printf("请输入要查找的字符:\n");
scanf("%c",x);
while(fscanf(fp,"%c",c)!=eof)
{
if(c==x)
{
flag=1;
break;
}
}
if(flag==1)
printf("文件中含有字符%c\n",x);
else
printf("文件中没有字符%c\n",x);
return 0;
}