我晕了晕了

xyjchinese 2006-02-04 07:20:09
我查了一个小时,没看出来哪错了,我看着没错啊,到底哪错了
我的目的是删除str1中的标点.

#include<iostream>
#include<string>
using namespace std;
int main()
{
string str1=("a,b.c!d\\e/f:gh");
string str2=(",.!\\/:\"");
string::size_type pos=0;
cout<<str1<<endl;
while((pos=str1.find_first_of(str2,pos)!=string::npos))
{
str1.erase(pos,1);
pos++;
cout<<str1<<endl;
}

return 0;
}
...全文
179 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
du51 2006-02-04
  • 打赏
  • 举报
回复
STL有那么好吗
iamcaicainiao 2006-02-04
  • 打赏
  • 举报
回复
呵呵,散分散分。
xyjchinese 2006-02-04
  • 打赏
  • 举报
回复
to 2楼,我知道,我只是测试一下这种方法
xyjchinese 2006-02-04
  • 打赏
  • 举报
回复
我晕,我找了半天,还真就没注意那括号~~~真晕,谢谢了
iamcaicainiao 2006-02-04
  • 打赏
  • 举报
回复
lz试试看就知道了。就是括号问题。lz的(())不是浪费吗?
这个就是涉及运算符优先级的问题,lz试试我改过的程序,就明8了。
iamcaicainiao 2006-02-04
  • 打赏
  • 举报
回复
#include<iostream>
#include<string>
using namespace std;
int main()
{
string str1=("a,b.c!d\\e/f:gh");
string str2=(",.!\\/:\"");
string::size_type pos=0;
cout<<str1<<endl;
while((pos=str1.find_first_of(str2,pos))!=string::npos)
{
str1.erase(pos,1);
pos++;
cout<<str1<<endl;
}

return 0;
}
这句话里的括号错了。正确如下:
while((pos=str1.find_first_of(str2,pos))!=string::npos)
屋顶上的老猫 2006-02-04
  • 打赏
  • 举报
回复
你这么做从根本上就不是正本清元的办法,很简单的问题,遍历str1的每个字符根据asc码进行判断不就完了!

64,683

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧