目录核心函数find函数substr函数数值转换输入样例输出样式c++相较于Java,python 并没有提供的字符串分割的函数split,因此需要自己进行编写。在实际的工作中这一功
c++相较于Java,python 并没有提供的字符串分割的函数split,因此需要自己进行编写。在实际的工作中这一功能会被经常使用,所以进行简单的记录一下。
代码实现的函数是调用String库中的find函数和substr函数。
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还支持以下的操作
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<iOStream>
#include<vector>
#include<string>
using namespace std;
void spiltStr(string str,const string & split,vector<string>&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<int>num;
vector<string>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<string>spiltStr的数值写入vector<int>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<<i<<" ";
}
cout<<endl;
cout<<target<<endl;
}
例程演示
到此这篇关于C++如何切割String对象的方法的文章就介绍到这了,更多相关C++ 切割String对象内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: C++如何切割String对象的方法
本文链接: https://www.lsjlt.com/news/148617.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0