C++如何切割String對(duì)象的方法
C++相較于Java,Python 并沒(méi)有提供的字符串分割的函數(shù)split,因此需要自己進(jìn)行編寫。在實(shí)際的工作中這一功能會(huì)被經(jīng)常使用,所以進(jìn)行簡(jiǎn)單的記錄一下。
核心函數(shù)
代碼實(shí)現(xiàn)的函數(shù)是調(diào)用String庫(kù)中的find函數(shù)和substr函數(shù)。
find函數(shù)
size_type find(const basic_string &str,size_type pos=0)
find函數(shù)完成最簡(jiǎn)單的搜索,它查找參數(shù)指定的字符串(str),若找到返回一個(gè)String::size_type的值,用來(lái)表示匹配發(fā)生位置的下標(biāo)。若未找到,則返回一個(gè)名為string::npos的static成員。C++標(biāo)準(zhǔn)庫(kù)將npos定義為一個(gè)const string ::size_type類型,并初始化值為-1。由于npos是一個(gè)unsigned類型,此初值意味著npos等于任何string最大的可能大小。
參數(shù)str,pos表示從pos位置中開(kāi)始查找str
除了find 操作,string還支持以下的操作
- str.find(args) 查找str中args第一次出現(xiàn)的位置
- str.rfind(args) 查找str中args最后一次出現(xiàn)的位置
- str.find_first_of(args) 查找str中args中第一個(gè)字符第一次出現(xiàn)的位置
- str.find_last_of(args) 查找str中args中第一個(gè)字符最后一次出現(xiàn)的位置
- str.find_first_not_of(args) 查找str中args中第一個(gè)不在atgs中的字符
- str.find_last_not_of(args) 查找str中args中最后一個(gè)不在atgs中的字符
substr函數(shù)
string substr(size_type pos=0,size_type count=npos)
substr主要功能是復(fù)制字符串,要求從指定的位置pos開(kāi)始,并具有指定的長(zhǎng)度count。若未指定長(zhǎng)度或者pos+count>源字符串的長(zhǎng)度,則子字符串將延續(xù)到源字符串的結(jié)尾
數(shù)值轉(zhuǎn)換
由于本次樣例中需要將string類型轉(zhuǎn)換為int類型,我們簡(jiǎn)單介紹以下常見(jiàn)的string的數(shù)值轉(zhuǎn)換
int轉(zhuǎn)換成string
int i=42; string s=to_string(i);
string 轉(zhuǎn)換成int
string str='42'; stoi(str);
輸入樣例
nums = [3,2,4], target = 6
輸出樣式
3 2 4
6
代碼實(shí)現(xiàn)
#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 復(fù)制字符串,起始位置,復(fù)制字符數(shù)目
? ? ? ? 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的數(shù)值寫入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;
? ??
}例程演示

到此這篇關(guān)于C++如何切割String對(duì)象的方法的文章就介紹到這了,更多相關(guān)C++ 切割String對(duì)象內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
一文帶你了解C++中的右值引用與移動(dòng)語(yǔ)義
本篇文章主要為大家詳細(xì)介紹了C++中的右值引用與移動(dòng)語(yǔ)義的相關(guān)知識(shí),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2023-03-03
教你如何使用qt quick-PathView實(shí)現(xiàn)好看的home界面
pathView的使用類似與ListView,都需要模型(model)和代理(delegate),只不過(guò)pathView多了一個(gè)路徑(path)屬性,顧名思義路徑就是item滑動(dòng)的路徑,下面給大家分享qt quick-PathView實(shí)現(xiàn)好看的home界面,一起看看吧2021-06-06
C++實(shí)現(xiàn)LeetCode(127.詞語(yǔ)階梯)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(127.詞語(yǔ)階梯),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
gcc中extra qualification錯(cuò)誤的解決
今天小編就為大家分享一篇gcc中extra qualification錯(cuò)誤的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12
C語(yǔ)言中fchdir()函數(shù)和rewinddir()函數(shù)的使用詳解
這篇文章主要介紹了C語(yǔ)言中fchdir()函數(shù)和rewinddir()函數(shù)的使用詳解,是C語(yǔ)言入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-09-09
C++算法學(xué)習(xí)之貪心算法的應(yīng)用
貪心算法是指,在對(duì)問(wèn)題求解時(shí),總是做出在當(dāng)前看來(lái)是最好的選擇。本文為大家準(zhǔn)備了幾個(gè)示例,從而能深入了解貪心算法的應(yīng)用,需要的可以參考一下2022-05-05

