c/c++字符串處理大集合

轉自:https://blog.csdn.net/wallwind/article/details/6827863

參考:https://www.cnblogs.com/xFreedom/archive/2011/05/16/2048037.html

在此列舉c/c++字符串處理函數,希望對初學者有一定幫助

c

char st[100];

1. 字符串長度

strlen(st);

2.字符串比較

strcmp(st1, st2);

strncmp(st1, st2, n); //把st1,st2的前n個進行比較

3.附加

strcat(st1, st2);

strncat(st1, st2, n);//n標誌連接st2的前n個給st1,在最後不要加'\0'

4.替換(拷貝/複製)

strcpy(st1, st2);

strncpy(st1, st2, n);//n表示複製st2的前n個給st1,在最後要加'\0'

5.查找

where = strchr(st, ch);//ch爲要找的字符

where = strspn(st1, st2);//查找字符串

where = strstr(st1, st2);

c++

#include <string>

string str;

1.字符串長度

len = strt.length();

len = str.size();

2.字符串比較

可以直接比較

也可以

str1.compare(str2);

str1.compare(pos1, len1, str2, pos2,len2);//值爲負、0、正

nops長度到完

3.附加

str1 += str;

str1.append(str2);

str1.append(str2, pos2, len2);

4.字符串提取

str2 = str1.substr();

str2 = str1.substr(pos1);

str2 = str1.substr(pos1, len1);

string a = s.substr(0, 4);//獲得字符串s中 從第0位開始的長度爲4的字符串

5.字符串搜索

where = str1.find(str2);

where = str1.find(str2, pos1);//pos1是從str1的第幾位開始

where = str1.rfind(str2);//從後往前搜

6.插入字符串

str1.insert(pos1, str2);

str1.insert(pos1, str2, pos2, len2);

str1.insert(pos1, numchar, char); //numchar是插入次數,char是要插入的字符

7.替換字符串

str1.replace(pos1, str2);

str1.replace(pos1, str2, pos2, len2);

8.刪除字符串

str.erase(pos, len);

str.clear();

9.交換字符串

swap(str1, str2);

 

C++中string類常用算法

string類的構造函數:

string(const char *s); //用char類型的字符串s初始化

string(int n, char c); //用n個字符c初始化

此外,string類還支持默認構造函數和複製構造函數,如string s1; string s2 = "hello";都是正確的寫法

當構造的string太長而無法表達時會爆出length_error異常

string類的字符操作:

const char &operator[](int n)const;

const char &at(int n)const;

char &operator[](int n);

char &at(int n);

operator[]和at()均返回當前字符串中第n個字符的位置,但at函數提供範圍檢查,當越界時會拋出out_of_range異常,下標運算符[]不提供檢查訪問。

const char *data()const; //返回一個非null終止的c字符數組

const char *c_str()const; //返回一個以null終止的c字符串

int copy(char *s, int n, int pos = 0)const; //把當前串中以pos開始的n個字符拷貝到以s爲起始位置的字符數組,返回實際拷貝的數目。

string的特性描述:

int capacity()const; //返回當前容量(即string中不必增加內存即可存放的元素個數)

int max_size()const; //返回string對象中可存放的最大字符串的長度

int size()const; //返回當前字符串的大小

int length()const; //返回當前字符串的長度

bool empty()const; //當前字符串是否爲空

void resize(int len, char c); //把字符串當前大小置爲len,並用字符c填充不足的部分

string類的輸入輸出操作

string類重載運算符operaator>> //用於輸入

重載operator<<//用於輸出

函數getline(istream &in, string &s);//用於從輸入流in中讀取字符串到s中,以換行符‘\n’分開

 

string的賦值

string &operator=(const string &s); //把字符串s賦給當前字符串

string &assign(const char *s); //用c類型字符串s賦值

string &assign(const char *s, int n); //用c字符串s開始的n個字符串賦值

string &assign(const string &s); //把字符串s賦給當前字符串

string &assign(int n, char c); //用n個字符c賦值給當前字符串

string &assign(const string &s, int start, int n); //把字符串s中從start開始的n個字符賦給當前字符串

string &assign(const_iterator first, const_iterator last); //把first和last迭代器之間的部分賦值給字符串

 

string的連接

string &operator+=(const string &s); //把字符串s連接到當前字符串的結尾

string &append(const char *s); //把c類型字符串s連接到當前字符串結尾

string &append(const char *s, int n); //把c類型字符串s的前n個字符連接到當前字符串結尾

string &append(const string &s); //同operator+=()

string &append(const string &s, int pos, int n); //把字符串s中從pos開始的n個字符連接到當前字符串的結尾

string &append(int n, char c); //在當前字符串結尾添加n個字符c

string &append(const_iterator first, const_iterator last); //把迭代器first和last之間的部分連接到當前字符串的結尾

 

string的比較

bool operator==(const string &s1, const strinf &s2) const; //比較兩個字符串是否相等

運算符“>”,"<",">=","<=","!="均被重載用於字符串的比較

int compare(const string &s) const; //比較當前字符串和s的大小

int compare(int pos, int n, const string &s)const; //比較當前字符串從pos開始的n個字符組成的字符串與s的大小

int compare(int pos, int n, const string &s, int pos2, int n2)const;//比較當前字符串從pos開始的n個字符與s中pos2開始的n2個字符組成的字符串的大小

int compare(const char *s)const;

int compare(int pos, int n, const char *s)const;

int compare(int pos, int n, const char *s, int pos2)const;

compare函數在>時返回1,<時返回-1,==時返回0

string的子串

string substr(int pos = 0, int n = npos)const; //返回pos開始的n個字符組成的字符串

string的交換

void swap(string &s2);

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章