C++STL之string (转)

在学习c++STL中的string,在这里做个笔记,以供自己以后翻阅和初学者参考。

1:string对象的定义和初始化以及读写

string s1;      默认构造函数,s1为空串

string s2(s1);   将s2初始化为s1的一个副本

string s3("valuee");   将s3初始化一个字符串面值副本

string s4(n,'c');   将s4 初始化为字符'c'的n个副本

cin>>s5;  读取有效字符到遇到空格

getline(cin,s6);  读取字符到遇到换行,空格可读入,知道‘\n’结束(练习在下一个代码中),

getline(cin,s7,'a'); 一个直到‘a’结束,其中任何字符包括'\n'都能够读入,可以试试题:UVa10361

下面看一个巩固练习:

 

[cpp] view plaincopyprint?在CODE上查看代码片派生到我的代码片
  1. #include <iostream> 
  2. #include <string> 
  3. using namespace std; 
  4. int main() 
  5.     string s1; 
  6.     s1="i love you"; 
  7.     string s2(s1);  //把s2初始化为s1的一个副本,注意写法,不能前面先定义s2的类型后面直接写,也不能定义两次s2 
  8.     string s3("value");  //将s3初始化一个字符串面值副本 
  9.     string s4(10,'s');   //将s4初始化为字符‘s'的10个副本 
  10.     /*注意字符串面值与标准库string不是同一个类型*/ 
  11.     cout<<s2<<" "<<s3<<" "<<s4<<endl; 
  12.     string s5; 
  13.     while(cin>>s5)  //这里可以输入“  hello world  ”测试,发现只读取有效字符到遇到空格结束 
  14.     { 
  15.         cout<<s5<<endl; 
  16.     } 
  17.     return 0; 
#include <iostream>
#include <string>
using namespace std;
int main()
{string s1;s1="i love you";string s2(s1);  //把s2初始化为s1的一个副本,注意写法,不能前面先定义s2的类型后面直接写,也不能定义两次s2string s3("value");  //将s3初始化一个字符串面值副本string s4(10,'s');   //将s4初始化为字符‘s'的10个副本/*注意字符串面值与标准库string不是同一个类型*/cout<<s2<<" "<<s3<<" "<<s4<<endl;string s5;while(cin>>s5)  //这里可以输入“  hello world  ”测试,发现只读取有效字符到遇到空格结束{cout<<s5<<endl;}return 0;
}

2:string对象操作

 

s.empty()  判断是否为空,bool型

s.size() 或 s.length() 返回字符的个数

s[n]  返回位置为n的字符,从0开始计数

s1+s2 连接,看下面例子:

    可用此方法给字符串后面添加字符如:s=s+'a';

    a:  string s2=s1+", ";  //对,把一个string对象和一个字符面值连接起来是允许的

    b:  string s4="hello "+", ";   //错,不能将两个字符串面值相加

    c:  string s5=s1+", "+"world";   //对,前面两个相加相当于一个string对象;

    d:  string s6="hello" + ", " +  s2;  //错

(注:字符串尾部追加还可用s.append("abc")函数添加)

s1=s2  替换

s1==s2  相等,返回true或false

!=,<,<=,>,>=  字符串比较,两个字符串短的与长的前面匹配,短的小于长的

巩固练习:

 

[cpp] view plaincopyprint?在CODE上查看代码片派生到我的代码片
  1. #include <iostream> 
  2. #include <string> 
  3. using namespace std; 
  4. int main() 
  5.     string str1; 
  6.     string str2("the size of "); 
  7.     string str3=" hello world  ";//空格不会忽略 
  8.     str3+=str2; 
  9.     str3.append("haha secessful"); 
  10.     cout<<str3<<endl; 
  11.     cout<<"the size of is "<<str2.size()<<endl; 
  12.     /*注意这里取长度的str2.size(),和str2.length(),但是注意str2.size()返回的值并不是int类型,
  13.     事实表明size_type存储的string长度是int所能存储的两倍*/ 
  14.     getline(cin,str1);  //read line at time until end-of-file,注意写法。 
  15.     while(!str1.empty())  //返回一个bool值,空的话返回true,否则返回false。 
  16.     { 
  17.         for(string::size_type i=0;i!=str1.size();++i)  //注意size_type类型 
  18.         { 
  19.             cout<<str1[i]; 
  20.         } 
  21.         cout<<endl;break; 
  22.     } 
  23.     return 0; 
#include <iostream>
#include <string>
using namespace std;
int main()
{string str1;string str2("the size of ");string str3=" hello world  ";//空格不会忽略str3+=str2;str3.append("haha secessful");cout<<str3<<endl;cout<<"the size of is "<<str2.size()<<endl;/*注意这里取长度的str2.size(),和str2.length(),但是注意str2.size()返回的值并不是int类型,事实表明size_type存储的string长度是int所能存储的两倍*/getline(cin,str1);  //read line at time until end-of-file,注意写法。while(!str1.empty())  //返回一个bool值,空的话返回true,否则返回false。{for(string::size_type i=0;i!=str1.size();++i)  //注意size_type类型{cout<<str1[i];}cout<<endl;break;}return 0;
}

 

3:string对象中字符的处理(头文件cctype)

 

    isalnum(c)  如果c是字母或数字,返回 true

    isalpha(c)  如果c是字母,返回true

    iscntrl(c)  c是控制符,返回true

    isdigit(c)  如果c是数组,返回true

    isgraph(c)  如果c不是空格,则可打印,,则为true

    islower(c)  如果c是小写字母,则为true

    isupper(c)  如果c是大写字符,则为true

    isprint(c)  如果c是可打印的字符,则为true

    ispunct(c)  如果c是标点符号,则为true

    isspace(c) 如果c是空白字符,则为true

    isxdigit(c) 如果c是十六进制数,则为true

    tolower(c) 如果c是大写字符,则返回其小写字母,否则直接返回c

    toupper(c)  跟tolower相反

看一个巩固练习代码:

 

[cpp] view plaincopyprint?在CODE上查看代码片派生到我的代码片
  1. #include <iostream> 
  2. #include <string> 
  3. #include <cctype> 
  4. using namespace std; 
  5. int main() 
  6.     string str1="Hello World!!!"; 
  7.     string::size_type punct_cnt = 0; 
  8.     for(string::size_type i=0;i!=str1.size();++i) 
  9.     { 
  10.         if(ispunct(str1[i])) 
  11.             ++punct_cnt; 
  12.         str1[i]=toupper(str1[i]); 
  13.     } 
  14.     cout<<"字符中标点符号有:"<<punct_cnt<<endl; 
  15.     cout<<str1<<endl; 
  16.     return 0; 
#include <iostream>
#include <string>
#include <cctype>
using namespace std;
int main()
{string str1="Hello World!!!";string::size_type punct_cnt = 0;for(string::size_type i=0;i!=str1.size();++i){if(ispunct(str1[i]))++punct_cnt;str1[i]=toupper(str1[i]);}cout<<"字符中标点符号有:"<<punct_cnt<<endl;cout<<str1<<endl;return 0;
}

4:string对象中一些函数

/*-------------------------插入函数----------------------------------包括迭代器操作和下标操作,下标操作更灵活*/

s.insert( it , p );  把字符串p插入到it的位置

s.insert(p,n,t);   迭代器p元素之前插入n个t的副本

s.insert(p,b,e);     迭代器p元素之前插入迭代器b到e之间的所有元素

s.insert(p,s2,poe2,len); 在下标p之前插入s2下标从poe2开始长度为len的元素

s.insert(pos,cp,len);  下标pos之前插入cp数组的前len个元素。

/*-----------------------替换函数-------------------------------*/

s.assign(b,e); 用迭代器b到e范围内的元素替换s

s.assign(n,t); 用n个t的副本替换s

a.assign(s1,pos2,len);从s1的下标pos2开始连续替换len个。

s.replace ( 3 , 3 , " good " ) ;   从第三个起连续三个替换为good

s.substr(i,j)   截取s串中从i到j的子串  //string::npos  判断字符串是否结束

/*-----------------------删除函数-----------------------------*/

s.erase( 3 )||s.erase ( 0 , 4 ) ;  删除第四个元素或第一到第五个元素

/*----------------------其他函数-----------------------------*/

s.find ( " cat " ) ;  超找第一个出现的字符串”cat“,返回其下标值,查不到返回 4294967295,也可查找字符;

s.append(args); 将args接到s的后面

s.compare ( " good " ) ;  s与”good“比较相等返回0,比"good"大返回1,小则返回-1;

reverse ( s.begin(), s.end () );  反向排序函数,即字符串反转函数

 

下面看一些巩固练习:

 

[cpp] view plaincopyprint?在CODE上查看代码片派生到我的代码片
  1. #include <iostream> 
  2. #include <algorithm> 
  3. #include <string> 
  4. #include <numeric> 
  5. using namespace std; 
  6. int main(int argc,char *argv[]) 
  7.     string s; 
  8.     s="54268713"; 
  9.     reverse(s.begin(),s.end()); //字符串反转 
  10.     cout<<s<<endl; 
  11.  
  12.     string s1="i love you"; 
  13.     string::iterator it; 
  14.     it=s1.begin(); 
  15.     s1.insert(it+1,'p');  //插入 
  16.     cout<<s1<<endl; 
  17.  
  18.     string s2("abc123456"); 
  19.     string::iterator it2=s2.begin(); 
  20.     s2.erase(it2+6);  //删除 
  21.     cout<<s2<<endl; 
  22.     s2.erase(it2,it2+3); 
  23.     cout<<s2<<endl; 
  24.     s2.replace(2,1,"good");  //替换 
  25.     cout<<s2<<endl; 
  26.     cout<<s2.find("good")<<endl;  //搜索返回下标值 
  27.     cout<<s2.compare("12good56")<<endl;  //比较,自行修改值看其返回值 
  28.     cout<<s2.compare("12good56758")<<endl; 
  29.  
  30.     return 0; 
#include <iostream>
#include <algorithm>
#include <string>
#include <numeric>
using namespace std;
int main(int argc,char *argv[])
{string s;s="54268713";reverse(s.begin(),s.end()); //字符串反转cout<<s<<endl;string s1="i love you";string::iterator it;it=s1.begin();s1.insert(it+1,'p');  //插入cout<<s1<<endl;string s2("abc123456");string::iterator it2=s2.begin();s2.erase(it2+6);  //删除cout<<s2<<endl;s2.erase(it2,it2+3);cout<<s2<<endl;s2.replace(2,1,"good");  //替换cout<<s2<<endl;cout<<s2.find("good")<<endl;  //搜索返回下标值cout<<s2.compare("12good56")<<endl;  //比较,自行修改值看其返回值cout<<s2.compare("12good56758")<<endl;return 0;
}

5:string的一些常用操作及用法

***string对象作为vector元素

***string对象的数字化处理

***string对象与sscanf函数

直接代码:

 

[cpp] view plaincopyprint?在CODE上查看代码片派生到我的代码片
  1. #include <iostream> 
  2. #include <algorithm> 
  3. #include <string> 
  4. #include <numeric> 
  5. #include <vector> 
  6. #include <cstdio> 
  7. using namespace std; 
  8. int main(int argc,char *argv[]) 
  9.     vector<string> v;   //vector的string 
  10.     v.push_back("Iack"); 
  11.     v.push_back("Mike"); 
  12.     v.push_back("Tom cluce"); 
  13.     cout<<v[0]<<endl; 
  14.     cout<<v[1][1]<<endl; 
  15.     cout<<v[2].size()<<endl; 
  16.  
  17.     char s3[100],s2[100]; 
  18.     string str3,str2; 
  19.     int ab,ac,ad; 
  20.     sscanf("abc fsaf","%s %s",s2,s3);  //注意string不能直接用于sscanf 
  21.     str3=s3;str2=s2; 
  22.     cout<<str3<<" "<<str2<<endl; 
  23.     sscanf("4,5$10000","%d,%d$%d",&ab,&ac,&ad); 
  24.     cout<<ab<<" "<<ac<<" "<<ad<<endl; 
  25.  
  26.     char s[200]; 
  27.     cin>>s; 
  28.     cin>>s; 
  29.     string s1=s; 
  30.     printf(s1.c_str());  //c输出字符串对象 
  31.  
  32.     return 0; 
#include <iostream>
#include <algorithm>
#include <string>
#include <numeric>
#include <vector>
#include <cstdio>
using namespace std;
int main(int argc,char *argv[])
{vector<string> v;   //vector的stringv.push_back("Iack");v.push_back("Mike");v.push_back("Tom cluce");cout<<v[0]<<endl;cout<<v[1][1]<<endl;cout<<v[2].size()<<endl;char s3[100],s2[100];string str3,str2;int ab,ac,ad;sscanf("abc fsaf","%s %s",s2,s3);  //注意string不能直接用于sscanfstr3=s3;str2=s2;cout<<str3<<" "<<str2<<endl;sscanf("4,5$10000","%d,%d$%d",&ab,&ac,&ad);cout<<ab<<" "<<ac<<" "<<ad<<endl;char s[200];cin>>s;cin>>s;string s1=s;printf(s1.c_str());  //c输出字符串对象return 0;
}

6:string与数值的相互转换

注意下面c++的两个转化函数,比较好用,也比较常用、

 

[cpp] view plaincopyprint?在CODE上查看代码片派生到我的代码片
  1. #include <iostream> 
  2. #include <algorithm> 
  3. #include <string> 
  4. #include <numeric> 
  5. #include <vector> 
  6. #include <cstdio> 
  7. #include <sstream> 
  8. using namespace std; 
  9.  
  10. //c++方法:将数值转换为string 
  11. string convert_to_string(double x) 
  12.     ostringstream o; 
  13.     if(o << x) 
  14.         return o.str(); 
  15.     return "conversion error"; 
  16. //c++方法,将string转化为数值 
  17. double convert_from_string(const string &s) 
  18.     istringstream i(s); 
  19.     double x; 
  20.     if(i >> x) 
  21.         return x; 
  22.     return 0.0; 
  23. int main(int argc,char *argv[]) 
  24.     //将数值转换为string的第一种方法:c方法 
  25.     char b[10]; 
  26.     string a; 
  27.     sprintf(b,"%d",1975);  //数值转化为string 
  28.     a=b; 
  29.     cout<<a<<endl; 
  30.  
  31.     string cc=convert_to_string(1976); 
  32.     cout<<cc<<endl; 
  33.  
  34.     string dd="115165"; 
  35.     int p=convert_from_string(dd)+2; 
  36.     cout<<p<<endl; 
  37.     return 0; 
#include <iostream>
#include <algorithm>
#include <string>
#include <numeric>
#include <vector>
#include <cstdio>
#include <sstream>
using namespace std;//c++方法:将数值转换为string
string convert_to_string(double x)
{ostringstream o;if(o << x)return o.str();return "conversion error";
}
//c++方法,将string转化为数值
double convert_from_string(const string &s)
{istringstream i(s);double x;if(i >> x)return x;return 0.0;
}
int main(int argc,char *argv[])
{//将数值转换为string的第一种方法:c方法char b[10];string a;sprintf(b,"%d",1975);  //数值转化为stringa=b;cout<<a<<endl;string cc=convert_to_string(1976);cout<<cc<<endl;string dd="115165";int p=convert_from_string(dd)+2;cout<<p<<endl;return 0;
}

下面推荐一些字符串的题目 hdoj 2017 字符串中统计数字,直接调用上面s.digit()函数 hdoj 1020  判断输出重复、水题、 hdoj 1062 逆转字符串 注意1:getchar()吸收3后'\n',2:空格不止有一个 hdoj 1039,字符串处理,清晰思路,可以写三个判断条件的3个函数,调用函数判断,思路清晰,容易判断; hdoj 1088 对字符串按一个一个处理。一次性输入一行不好控制 hdoj 1113 map容器+字典序。值得做 hdoj 1161 tolower() 函数转化为小写就ok 1200、1251、1256、1288、1321、1328、1379、1804、1860、 1982、1984、2017、2024、2025、2026、2027、2043、2052、2054、2072、2074、2087、2131、 2137、2140、2163、2203、2206、2352、2500、2549、2564、2565、2567、2572、2609、2607、 2707、2708、2719、2721、2723、

比较详细,希望帮助到了跟我一样正在学习中的菜鸟、、、

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/296208.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

当年的毒王熊猫烧香,现在怎么样了?

全世界只有3.14 % 的人关注了爆炸吧知识放假&#xff0c;小编来到了远在73公里之外的天后宫&#xff0c;终于是了了本命年的一桩心事。回想上一个本命年&#xff0c;当时小编还是沉迷扫雷和蜘蛛纸牌的孩子...但当时却发生了一件令我很不爽的事——“熊猫烧香”席卷全国&#xf…

$query php,phpQuery让php处理html代码像jQuery一样方便

简介如何在php中方便地解析html代码&#xff0c;估计是每个phper都会遇到的问题。用phpQuery就可以让php处理html代码像jQuery一样方便。DEMO我下的是onefile版&#xff1a;phpQuery-0.9.5.386-onefile.zip然后在项目中引用。html文件test.html&#xff1a;Spiderman City Driv…

那个成人总会遇到的小问题……

结语超模君就问问&#xff1a;我还有机会10万&#xff0b;吗&#xff1f;&#xff08;溜了溜了&#xff09;莱布尼茨德国数学家莱布尼茨&#xff0c;被后人誉为“百科全书式的天才”&#xff0c;他的研究涉及逻辑学、力学等40多个领域。他创建了数学理论&#xff1a;微积分学。…

java继承接口和泛型,JavaSE习题 继承接口和泛型

问答题&#xff1a;1.子类在什么情况下可以继承父类友好成员&#xff1f;答&#xff1a;在同一个包内2.子类通过怎样的方法可以隐藏继承的成员变量&#xff1f;答&#xff1a;声明一个与父类相同变量名的成员变量3.子类重写继承的方法原则是什么&#xff1f;答&#xff1a;保证…

Github CodeSpaces 使用及定制化

Github CodeSpaces 使用及定制化IntroGithub 最近推出了很多令人兴奋的新功能&#xff0c;最近使用了 Github CodeSpaces&#xff0c;觉得还是挺不错的&#xff0c;CodeSpaces 相当于自己有了一个云主机&#xff0c;真正实现了云端开发&#xff0c;CodeSpaces 和 Github 做了很…

nat+端口转发,使得宿主机secureCRT可以访问vbox里linux虚拟机

为什么80%的码农都做不了架构师&#xff1f;>>> 环境&#xff1a;vbox或者叫vitrualbox连接虚拟机&#xff0c;由于公司内网不能分配IP&#xff08;不知道是不是这个原因&#xff09;&#xff0c;虚拟机用桥接得不到IP&#xff0c;没法实现虚拟机和宿主互相访问&am…

男人可以有多敷衍?

1 现在更流行「红茶女生」&#xff1f;&#xff08;via.白头叔&#xff09;▼2 谢谢&#xff0c;有被冒犯到&#xff08;素材来源网络&#xff0c;侵删&#xff09;▼3 天使与恶魔▼4 男朋友可以多敷衍&#xff1f;▼5 你的高原红&#xff0c;像极了妈妈的巴掌印&#xff…

linux 内核代码构架图

转载于:https://www.cnblogs.com/kuainiao/archive/2012/12/17/2822384.html

Win11开始大范围推送!

微软宣布 Windows11 现已开始向更多符合最低硬件要求的电脑推送。预计到 2022 年年中&#xff0c;所有符合条件的电脑都可以免费升级到 Windows 11。微软将根据硬件条件、可靠性、使用时间&#xff0c;及其它会影响升级后使用体验的因素&#xff0c;为 Windows 10 电脑分阶段推…

有什么看起来很难,但是其实很简单的题目

全世界只有3.14 % 的人关注了爆炸吧知识做题其实很简单今天超模君一进办公室就感觉充满“杀气”&#xff0c;果不其然&#xff0c;一抬头就看见小天拿着一张纸对着我坏笑。莫非这家伙又要我折纸&#xff1f;拿过纸张一看&#xff0c;虽然密密麻麻的一大堆公式&#xff0c;但我相…

双11,2分钟狂挣20亿的神秘大厂,急招.NET!

双11小米开门红&#xff0c;2分钟不到突破20亿&#xff0c;于是机智的我又去逛了下小米的招聘官网&#xff1a;招5年左右.NET&#xff0c;35k左右&#xff0c;14薪&#xff0c;要求WPF和自动化&#xff0c;真香&#xff01;回首牛年2个跳槽季&#xff0c;招WPF的大厂太多了&…

炸了!刚刚数学家获得了2020年诺贝尔物理学奖!没想到诺奖也能蝉联.......

全世界只有3.14 % 的人关注了爆炸吧知识就在刚刚&#xff0c;万众瞩目的2020年诺贝尔奖物理学奖获得者确定了&#xff01;他们就是——天体物理学家&#xff08;该领域连续两年获得诺奖&#xff09;物理学奖得主罗格彭罗斯爵士&#xff08;Roger penrose&#xff09;&#xff0…

Envoy实现.NET架构的网关(五)集成Redis实现限流

.NET网关与Gateway实战-Envoy与kong课程什么是限流限流即限制并发量&#xff0c;限制某一段时间只有指定数量的请求进入后台服务器&#xff0c;遇到流量高峰期或者流量突增时&#xff0c;把流量速率限制在系统所能接受的合理范围之内&#xff0c;不至于让系统被高流量击垮。而E…

使用 Daynamic 动态添加属性

所谓的Dynamic 动态类型&#xff0c;页面也要是动态的&#xff08;强撸&#xff09; 很简单的 直接上代码&#xff1a; //案例一 DynamicpersonCollection new ObservableCollection(); for (var i 0; i < 10; i) { dynamic p new ExpandoObject(); ((IDictionary<str…

豆瓣9分+纪录片,每一部都美到窒息......

全世界只有3.14 % 的人关注了爆炸吧知识自然类的纪录片一直是BBC的金字招牌&#xff0c;制作精良的纪录片&#xff0c;不仅能让孩子享受视觉的艺术&#xff0c;还能通过独特的视角去解读大自然&#xff0c;真正激发出孩子探索世界的热情。也适合大人影迷们在看了N部电影后视觉疲…

程序怎么跑着 就卡死,句柄泄漏,内存泄漏了

一&#xff1a;背景 1. 讲故事上个月中旬&#xff0c;星球里的一位朋友在微信找我&#xff0c;说他的程序跑着跑着内存会不断的缓慢增长并无法释放&#xff0c;寻求如何解决 &#xff1f;得&#xff0c;看样子星球还得好好弄&#xff01;&#xff01;&#xff01;&#x1f602;…

活久见!一美国大爷发明了永不掉链子的自行车,垂直踩踏即可驱动

全世界只有3.14 % 的人关注了爆炸吧知识©文丨 直观学机械、自行车网最近&#xff0c;一款能永不掉链子的自行车特别火&#xff0c;咱们今天来看看它长什么样。这款自行车据说是由美国洛杉矶的一位老大爷 Rodger Parker 设计的&#xff0c;名叫&#xff1a;NuBike。设计自行…

学习xss的一些记录(一)

最近正在学习关于xss的一些知识&#xff0c;作为一个前端开发者&#xff0c;这个知识也是基础的&#xff0c;以前也没怎么好好学习与总结&#xff0c;深感惭愧&#xff0c;接下来的几天时间好好补习下。 xss是什么 xss的全称是Cross Site Scripting&#xff0c;即跨站脚本。攻击…

使用Hot Chocolate创建ASP.NET Core GraphQL服务

GraphQL介绍GraphQL是一个用于API的查询语言&#xff0c;是一个使用基于类型系统来执行查询的服务端运行时。GraphQL对你的API中的数据提供了一套易于理解的完整描述&#xff0c;使得客户端能够准确地获得它需要的数据&#xff0c;而且没有任何冗余。Hot Chocolate介绍Hot Choc…

MFC中的文件读写技术

计算机室如何管理自身所存放着的大量的信息的呢&#xff1f;windows的磁盘管理程序为我们提供了一套严密而又高效的信息组织形式--硬盘上的信息是以文件的形式被管理的。 面向存储的文件技术 什么是文件&#xff1f;计算机中&#xff0c;一篇文章、一幅图片、一个程序等都是以文…