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);

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