实验目的:
输入一串字符,再输入一个指定字符,将字符串中删去指定字符再显示出来。要求程序把输入字符串、删除指定字符和显示字符串的功能分别在各自单独的.cpp文件由外部函数来处理,主文件中的主函数只作调用各外部函数实现程序功能。
思路:
我的思路是输入一个字符串和一个指定的字符,用for循环在该循环中找到与指定字符(target)一样的字符,然后通过把后面的字符向前移一位来达到删除的目的。
第一次写的问题代码:
#include<iostream>
using namespace std; //写在这里是因为后面包含的文件中没有using namespace std;,但部分用到了std中的cout
#include"input.cpp"
#include"output.cpp"
#include"del.cpp"
using namespace std;
int main()
{
char *p = new char;
input(p);
del(p);
output(p);
system("pause");
}
///////////////////////////////////////////////////////////
void input(char *p)
{
cout << "please input a string:";
cin >> p;
}
/////////////////////////////////////////////////////////
void output(char *p)
{
cout << p << endl;
}
//有误的部分
void del(char *p)
{
char target;
cout << "please input a target:";
cin >> target;
int len = sizeof(p); //理解错误,误以为sizeof(p)会返回p所指向的字符串的长度
int j;
for (int i = 0; p[i]!=len-1; i++)
{
if (p[i] == target)
{
for(j = i; p[j]!=len-2; j++)
{
p[j] = p[j + 1];
}
p[j+1] = ' ';
len-=1;
}
}
}
错误分析:
上面的sizeof(p),实际上返回了指针p的长度,在这里指针的长度都是4字节,所以len=4,不等于字符串的有效长度。正确的做法应该是int len=strlen(p);
修改后的代码:
void del(char *p)
{
char target;
cout << "please input a target:";
cin >> target;
int j;
for (int i = 0; p[i]!=' '; i++) //使用了更加方便的做法
{
if (p[i] == target)
{
for(j = i; p[j]!=' '; j++)
{
p[j] = p[j + 1];
}
p[j+1] = ' ';
i=-1; //为了让它从头开始检查
}
}
}