日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

c++ string 删除字符_字符串操作的全面总结

發(fā)布時間:2024/7/5 c/c++ 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 c++ string 删除字符_字符串操作的全面总结 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

來自公眾號:C語言與cpp編程

字符串操作看似簡單,其實非常重要,不注意的話,經(jīng)常出現(xiàn)代碼運行結(jié)果和自己想要的不一致,甚至崩潰。本文總結(jié)了一些構(gòu)建string對象方法、修改string對象的方法、string類型的操作函數(shù)、string類型的查找、string對象的比較。

1 構(gòu)建string對象方法

首先,為了在我們的程序中使用string類型,我們必須包含頭文件 。如下:

#include

聲明一個字符串變量很簡單:

string Str;

這樣我們就聲明了一個字符串變量,但既然是一個類,就有構(gòu)造函數(shù)和析構(gòu)函數(shù)。上面的聲明沒有傳入?yún)?shù),所以就直接使用了string的默認的構(gòu)造函數(shù),這個函數(shù)所作的就是把Str初始化為一個空字符串。

String類的構(gòu)造函數(shù)和析構(gòu)函數(shù)如下:

String類函數(shù)說明string s;生成一個空字符串sstring s(s2);拷貝構(gòu)造函數(shù) 生成s2的復制品string s("value");用字符串value初始化sstring s(b,e);以區(qū)間b,e內(nèi)的字符作為字符串s的初值string s(cp,n);取字符數(shù)組,前n個字符作初值string s(s2,pos2);將字符串s2"始于位置pos2"部分當作字符串的初值string s(s2,pos1,len);將字符串s2內(nèi)"始于pos1且長度最多l(xiāng)en"的部分作為字符串的初值s.~string();銷毀所有字符,釋放內(nèi)存

代碼實例:

#include #include using namespace std;//20200527 測試字符串操作 C語言與CPP編程int main(){ string s1; cout <

** 運行結(jié)果**:

2 修改string對象的方法

與容器共有的 string 操作:

與容器共有的 string 操作方法說明s.insert(p,t);在迭代器 p 指向的元素之前插入一個值為 t 的新元素,返回指向新插入元素的迭代器s.insert(p,n,t);在迭代器 p 指向的元素之前插入 n 個值為 t 的新元素s.insert(p,b,e);在迭代器 p 指向的元素之前插入迭代器 b 和 e 標記范圍內(nèi)所有的元素。返回 voids.assign(b,e);在迭代器 b 和 e 標記范圍內(nèi)的元素替換 s。string類型,返回 s;容器類型返回 voids.assign(n,t);用值為 t 的 n 個副本替換 s。對于 string 類型,該操作返回 s;對于容器類型,則返回 voids.erase(p);刪除迭代器 p 指向的元素。返回一個迭代器,指向被 刪除元素后面的元素s.erase(b,e);刪除迭代器 b 和 e 標記范圍內(nèi)所有的元素。返回一個迭代器,指向被刪除元素段后面的第一個元素

代碼實例

#include #include using namespace std;//2020.05.27 測試字符串操作 公眾號:C語言與CPP編程int main(){ string s("hello"); string s2("abcdef"); string::iterator p = s.begin(); //迭代器p s.insert(p,'A'); //在迭代器p指向的s開始之前插入A cout << s << endl; //s為Ahello s.insert(p,3,'B'); //p指向返回的Ahello的A處,在A之前插入3個B cout << s << endl; //s為BBBAhello string::iterator b = s2.begin(); //迭代器b string::iterator e = s2.end(); //迭代器e //p = s.begin(); //p指向s s.insert(p,b,e); //在p指向的s之前插入b和e迭代器范圍內(nèi)的元素abcdef cout << s << endl; //s為abcdefBBBAhello s = "hello"; cout << s << endl; //s為hello s.assign(b,e); //s所有的元素倍替換為b到e之間的元素,b與e之間為s2 cout << s << endl; //s為abcdef s.assign(8,'K'); cout << s << endl; //s為KKKKKKKK p = s2.begin(); //迭代器p指向s2的a s2.erase(p); //刪除迭代器p指向的元素a cout << s2 << endl; //s2為bcdef p = s2.begin(); //a被刪除,p指向b p++; //指向c p++; //指向d string::iterator p2 = s2.end(); //p2迭代器指向f p2--; //指向e s2.erase(p,p2); //刪除p指向的d和p2指向的e之間的元素 cout << s2 << endl; //s2為bcf return 0;}

運行結(jié)果

運行結(jié)果

string 類型特有的版本

string以數(shù)組的形式存儲,可以用數(shù)組的下標進行修改操作:

string 修改操作方法說明s.insert(pos,n,c);在下標 pos 的元素之前插入 n 個字符 cs.insert(pos,s2);在下標 pos 的元素之前插入 string 對象 s2s.insert(pos,s2,pos2,len);在下標為 pos 的元素之前插入 s2 中從下標 pos2 開始的 len 個字符s.insert(pos,cp,len);在下標為 pos 打元素之前插入 cp 所指向數(shù)組的前l(fā)en 個字符s.insert(pos,cp);在下標為 pos 的元素之前插入 cp 所指向的以空字符結(jié)束的字符串副本s.assign(s2);用 s2 的副本替換 ss.assign(s2,pos2,len);用 s2 中從下標 pos2 開始的 len 個字符替換 ss.assign(cp,len);用 cp 所指向數(shù)組的前 len 個字符副本替換 ss.assign(cp);用 cp 所指向的以空字符結(jié)束的字符串替換 ss.erase(pos,len);刪除從下標 pos 開始的 len 個字符

代碼實例

#include #include using namespace std;//2020.05。27 測試字符串操作 公眾號:C語言與CPP編程int main(){ string s("hello"); string s2("abc"); s.insert(0,3,'A'); //在s下標是0之前插入3個A cout << s << endl; //s為AAAhello s.insert(5,s2); //在AAAhello下標是5的元素之前插入abc cout << s << endl; //s為AAAheabcllo s2 = "123456"; s.insert(0,s2,2,3); //在s的下標是0之前插入s2下標為2開始往后的3個元素345 cout << s << endl; //s為345AAAheabcllo char *cp = "Stately plup Buck"; s.assign (cp,7); cout << s << endl; //s為Stately s.assign(cp); //沒有長度,默認是拷貝全部 cout << s << endl; //s為Stately plup Buck s = "hello"; s.insert (0,cp,7); cout << s <

運行結(jié)果

運行結(jié)果

3 適合string類型操作的函數(shù)

  • substr()主要功能是復制子字符串,要求從指定位置開始,并具有指定的長度。
  • append() 方法在被選元素的結(jié)尾(仍然在內(nèi)部)插入指定內(nèi)容。提示:如需在被選元素的開頭插入內(nèi)容,請使用prepend()方法。
  • replace() 該函數(shù)返回一個字符串,其中指定的字符串已經(jīng)被替換為另一字符串,并且替換的次數(shù)也可以指定。

代碼實例:

#include #include using namespace std;//2020.05.27 測試字符串操作 公眾號:C語言與CPP編程int main(){ string s("Hello world"); string s2 = s.substr(6,5); //從第6個開始取5個 cout << s2 << endl ; //s2為world s2 = s.substr(6); //從第6個開始取拷貝所有的 cout << s2 << endl ; //s2為world s2 = s.substr(6); //s2拷貝s的全部,相當于s2=s cout << s2 << endl ; //s2為Hello world s = "C++ Primer"; s.append(" 3rd Ed"); //再s最后添加3rd Ed cout << s<< endl ; //s為C++ Primer 3rd Ed s = "C++ Primer"; s.insert(s.size()," 3rd Ed"); //最后插入 cout << s<< endl ; //s為C++ Primer 3rd Ed s.replace(11,3,"4th"); //下標11開始3個替換4th cout << s<< endl ; //s為C++ Primer 4th Ed s.replace(11,3,"Fourth"); //下標11開始3個替換Fourth cout << s<< endl ; //s為C++ Primer Fourth Ed s = "C++ Primer 3rd Ed"; //replace相當于先刪除后插入 s.erase (11,3); //刪除3rd s.insert(11,"Fourth"); //插入Fourth cout << s<< endl ; //s為C++ Primer Fourth Ed return 0;}

運行結(jié)果

運行結(jié)果

4 string類型的查找

查找函數(shù)說明s.find( args);在 s 中查找 args 的第一次出現(xiàn)s.rfind( args);在 s 中查找 args 的最后一次出現(xiàn)s.find_first_of( args);在 s 中查找 args 的任意字符的第一次出現(xiàn)s.find_last_of( args) ;在 s 中查找 args 的任意字符的最后一次出現(xiàn)s.find_first_not_of( args);在 s 中查找第一個不屬于 args 的字符s.find_last_not_of( args);在 s 中查找最后一個不屬于 args 的字符

代碼實例

#include #include using namespace std;//2020.05.27 測試字符串操作 公眾號:C語言與CPP編程int main(){ string name("AnnaBelle"); string::size_type pos1 = name.find("Bell"); cout << pos1 << endl; //返回下標4,如果沒找到返回npos if(pos1 == string::npos) cout << "沒找到!" << endl; else cout << "找到了!下標:" << pos1 <

運行結(jié)果

運行結(jié)果

5 string對象的比較

string對象比較函數(shù)compare用法說明str1.compare(str2);如果相等則輸出為0,str1>str2輸出大于0,否則,輸出小于0str1.compare(m,n,str2);str1的子串(從索引m開始,包含n個字符)與str2進行比較str1.compare(m,n,str2,m,n);str1的子串(從索引m開始,包含n個字符)與str2的子串(從索引m開始,包含n個字符)進行比較

代碼實例:

#include #include #include using std::cout;using std::endl;using std::cin;using std::string;int main(void){ string str1="hi,test,hello"; string str2="hi,test"; //字符串比較 if(str1.compare(str2)>0) printf("str1>str2"); else if(str1.compare(str2)<0) printf("str1

運行結(jié)果

運行結(jié)果

總結(jié)

以上是生活随笔為你收集整理的c++ string 删除字符_字符串操作的全面总结的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。