简介
string是字符串,c++相对c来说增加了这个,比字符数组方便很多。
有插入,替换,删除,反序,比较等功能。
接下来用一个程序将大部分功能串再一起,并在下方链接一些应用string解题的链接。
代码
/**************
Author:FrankYu
Date:2018/1/30
String
**************/
#include<iostream>
#include<string>
using namespace std;
string s;
string::iterator it;
void menu()
{
cout<<"********1.初始化 2.尾部追加字符(串)"<<endl;
cout<<"********3.插入字符 4.删除"<<endl;
cout<<"********5.替换字符(串) 6.搜索"<<endl;
cout<<"********7.比较 8.反向排序"<<endl;
cout<<"********9.显示 10.退出"<<endl;
}
void Inti()
{
int i;char ss[5000];
cout<<"********1.cin方法 2.scanf方法(速度快) 3.getline()方式(读入一行,包括空格等)"<<endl;
cin>>i;
cout<<"请输入一个字符串"<<endl;
switch(i)
{
case 1:cin>>s;break;
case 2:{scanf("%s",&ss);s=ss;}break;
case 3:{getchar();getline(cin,s);}break;
default:cout<<"输入错误!"<<endl;
}
}
void Add()
{
int i;char c;string str;
cout<<"********1.增加字符 2.增加字符串"<<endl;
cin>>i;
switch(i)
{
case 1:{
cout<<"请输入一个字符"<<endl;
cin>>c;
s=s+c;
}break;
case 2:{
cout<<"请输入一个字符串"<<endl;
cin>>str;
s=s+str;
}break;//append()函数也可以,既然+号都可以,就少记一个
default:cout<<"输入错误!"<<endl;
}
}
void Insert()
{
int place;char c;
cout<<"请输入在那个位置前插入(首元素为0):"<<endl;
cin>>place;
if(place<0||place>s.length())cout<<"不在范围内。"<<endl;
else
{cout<<"请输入字符:"<<endl;
cin>>c;
it=s.begin();
s.insert(it+place,c);
}
}
void Delete()
{
int i;int place,from,to;
cout<<"********1.删除某位置字符2.删除某区间字符"<<endl;
cout<<"********3.全部删除"<<endl;
cout<<"请输入菜单:"<<endl;
cin>>i;
switch(i)
{
case 1:{
cout<<"请输入该位置(首元素位置为0):"<<endl;
cin>>place;
it=s.begin();
s.erase(it+place);
}break;
case 2:{
cout<<"请输入起始位置和终止位置(删除时不包括终止位置元素):"<<endl;
cin>>from>>to;
it=s.begin();
s.erase(it+from,it+to);
}break;
case 3:s="";break;
default:cout<<"输入错误!"<<endl;
}
}
void Change()
{
int place;int num;string ss;
cout<<"请输入要替换的字符(串)的起始位置(首位置为0):"<<endl;
cin>>place;
cout<<"请输入需要被替换的字符(串)的长度:"<<endl;
cin>>num;
cout<<"请输入替换的字符(串):"<<endl;
cin>>ss;
s.replace(place,num,ss);
}
void Find()
{
string ss;int place;
cout<<"请输入你要查找的字符(串):"<<endl;
cin>>ss;
place=s.find(ss);
if(place<s.length())
cout<<"你要找的字符(串)的初始位置为"<<place<<endl;
else
cout<<"对不起,没有找到!"<<endl;
}
void Compare()
{
string ss;
cout<<"请输入要比较的字符(串):"<<endl;
cin>>ss;
if(!s.compare(ss))//相等
cout<<"两个字符串一样."<<endl;
else
cout<<"两个字符串不一样."<<endl;
}
void Sort()
{
reverse(s.begin(),s.end());
}
void Display()
{
cout<<s<<endl;
}
int main()
{
int i;
while(1)
{
menu();
cout<<"请输入菜单号:"<<endl;
cin>>i;
if(i==10)break;
switch(i)
{
case 1:Inti();break;
case 2:Add();break;
case 3:Insert();break;
case 4:Delete();break;
case 5:Change();break;
case 6:Find();break;
case 7:Compare();break;
case 8:Sort();break;
case 9:Display();break;
default:cout<<"输入错误!"<<endl;
}
}
return 0;
}
运行截图:
题的链接:
蓝桥杯 问题 1466字符串对比(c++实现)
http://blog.csdn.net/lady_killer9/article/details/79273833
蓝桥杯 问题 1094: 字符串的输入输出处理(c++实现)
http://blog.csdn.net/lady_killer9/article/details/79273801
蓝桥杯 问题 1093: 字符逆序(c++实现 string)
http://blog.csdn.net/lady_killer9/article/details/79273758
更多数据结构与算法实现:
数据结构(严蔚敏版)与算法的实现(含全部代码)
有问题请下方评论,转载请注明出处,并附有原文链接,谢谢!如有侵权,请及时联系。
版权声明:本文为lady_killer9原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。