C++怎么切割String对象
这篇文章主要讲解了"C++怎么切割String对象",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"C++怎么切割String对象"吧!
核心函数
代码实现的函数是调用String库中的find函数和substr函数。
find函数
size_type find(const basic_string &str,size_type pos=0)
find函数完成最简单的搜索,它查找参数指定的字符串(str),若找到返回一个String::size_type的值,用来表示匹配发生位置的下标。若未找到,则返回一个名为string::npos的static成员。C++标准库将npos定义为一个const string ::size_type类型,并初始化值为-1。由于npos是一个unsigned类型,此初值意味着npos等于任何string最大的可能大小。
参数str,pos表示从pos位置中开始查找str
除了find 操作,string还支持以下的操作
str.find(args) 查找str中args第一次出现的位置
str.rfind(args) 查找str中args最后一次出现的位置
str.find_first_of(args) 查找str中args中第一个字符第一次出现的位置
str.find_last_of(args) 查找str中args中第一个字符最后一次出现的位置
str.find_first_not_of(args) 查找str中args中第一个不在atgs中的字符
str.find_last_not_of(args) 查找str中args中最后一个不在atgs中的字符
substr函数
string substr(size_type pos=0,size_type count=npos)
substr主要功能是复制字符串,要求从指定的位置pos开始,并具有指定的长度count。若未指定长度或者pos+count>源字符串的长度,则子字符串将延续到源字符串的结尾
数值转换
由于本次样例中需要将string类型转换为int类型,我们简单介绍以下常见的string的数值转换
int转换成string
int i=42;string s=to_string(i);
string 转换成int
string str='42';stoi(str);
输入样例
nums = [3,2,4], target = 6
输出样式
3 2 4
6
代码实现
#include#include #include using namespace std;void spiltStr(string str,const string & split,vector &strlist){ strlist.clear(); if(str=="") return; string strs=str+split; size_t pos=strs.find(split); int steps=split.size(); while(pos!=strs.npos) { //substr 复制字符串,起始位置,复制字符数目 string temp=strs.substr(0,pos); strlist.push_back(temp); strs=strs.substr(pos+steps,strs.size()); pos=strs.find(split); }}int main(){ vector num; vector strlist; string inputStr; string tempStr; int target; getline(cin,inputStr); if(inputStr=="") { return 0; } //分割输入的字符串 spiltStr(inputStr,"[",strlist); spiltStr(strlist[1],"]",strlist); spiltStr(strlist[0],",",strlist); //将vector spiltStr的数值写入vector nums中 for(auto i:strlist) { num.push_back(stoi(i)); } spiltStr(inputStr,"=",strlist); // spiltStr(strlist.back(),"=",strlist); target=stoi(strlist.back()); for(auto i:num) { cout< 例程演示
感谢各位的阅读,以上就是"C++怎么切割String对象"的内容了,经过本文的学习后,相信大家对C++怎么切割String对象这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!