C++ String 操作学习

C++ String的参考手册 

需要掌握的操作:(参考-标准C++中的string类的用法总结

一、string类的构造函数:

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

string(int n,char c);     //用n个字符c初始化
此外,string类还支持默认构造函数和复制构造函数

例子:string s1="Nick";
string s2("Smith");
char a[]="nick";
string s3=s1;
string s4(a);//感觉C++中的string好强大,完全兼容C—style的字符串

二、string类的输入输出操作:

(重载运算符operator>>用于输入,同样重载运算符operator<<用于输出操作)

getline(istream &in,string &s);用于从输入流in中读取字符串到s中,以换行符'\n'分开例子:getline(cin,s3);

三、string类的字符操作:

operator[]和at()均返回当前字符串中第n个字符的位置,但at函数提供范围检查,当越界时会抛出out_of_range异常,下标运算符[]不提供检查访问。例子 char c=s1[1]

四、string的符号操作:

运算符">","<",">=","<=","!=","=="均被重载用于字符串的比较;

string &operator+=(const string &s);//把字符串s连接到当前字符串的结尾 

五、string的子串和查找:
字串:

string substr(int pos = 0,int n = npos) const;//返回pos开始的n个字符组成的字符串

例子 string s5=s3.substr(1,3);//从pos=1开始的三个字符

string类的查找函数: 

int find(char c, int pos = 0) const;//从pos开始查找字符c在当前字符串的位置
int find(const char *s, int pos = 0) const;//从pos开始查找字符串s在当前串中的位置

例子 cout<<s3.find("th")<<endl;//返回7

总结:操作

#include<iostream>
#include<string>
using namespace std;
int main()
{
	string s1="Nick";
	string s2("Smith");
	char a[]="nick";
	string s3=s1;
	string s4(a);
	//getline(cin,s3);
	s3.append(s2);
	cout<<s3<<endl;//s3=nicksimth
	//s3.swap(s1);
	string s5=s3.substr(1,3);//从pos=1开始的三个字符
	cout<<s5<<endl;
	cout<<s3.find("th")<<endl;//输出7
	return 0;
}

程序题目:

一、字符串倒置

void stringReverse(string &s)
{
	int len=s.length();
	char c;
	for (int i=0;i<len/2;++i)
	{
		c=s[i];
		s[i]=s[len-1-i];
		s[len-1-i]=c;
	}
}
二、一句话按照单词倒置  例如"i come from nanjing."输出结果为"nanjing. come from i"。

#include<iostream>
#include<string>
#include<vector>
using namespace std;
void stringReverse(string &s)
{
	int len=s.length();
	char c;
	for (int i=0;i<len/2;++i)
	{
		c=s[i];
		s[i]=s[len-1-i];
		s[len-1-i]=c;
	}
}
void stringReversePart(int p1,int p2,string &s)//本质是头尾颠倒互换,找准头尾字符串的位置
{
	if (p1>=p2)
	{
		return;
	}
	int len=p2-p1+1;
	char c;
	for (int i=p1,cout=0;i<p1+len/2;++i,++cout)
	{
		c=s[i];
		s[i]=s[p1+len-1-cout];//最后一个字符的位置是s[p1+len-1]
		s[p1+len-1-cout]=c;
	}
}
int main()
{
	string s="wang qian.";
	string r="rong";
	string out;
	int len=s.length();
	cout<<"The original name is:"<<s<<endl;
	stringReverse(s);
	cout<<"After reverse:"<<s<<endl;
	//stringReversePart(1,2,r);
	int i=0;
	int begin=0;
	int end=0;
	char c;
	while (i<len)
	{
		while (i<len&&s[i]!=' ') //注意这个顺序
		{
			++i;
			end++;
		}
		++i;
		end--;
		while (end>begin)
		{
			c=s[begin];
			s[begin]=s[end];
			s[end]=c;
			begin++;
			end--;
		}
		begin=i;
		end=i;
	}
	cout<<"After reverse by word:"<<s<<endl;
	return 0;
}
结果输出:







评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值