【C++基础】字符串的基本操作

上文我们已经了解了字符串的赋值及输入,那么我们如何处理输入的字符呢?

字符串基本操作

1.字符串的拼接

可使用'+'、'+='进行连接,亦可用append函数进行连接,详细操作见以下代码:

#include<iostream>
#include<string>
using namespace std;
int main(){
	string s1,s2,s3;
	s1="mail ";
	s2="time sh ";
	s3=s1+s2;  //使用'+'拼接 
	cout<<"s3="<<s3<<endl; 
	s3=s2+s1; //字符串拼接注意前后顺序 
	cout<<"s3="<<s3<<endl;
	
	s1+=s2;  //使用"+="拼接 
	cout<<"s1="<<s1<<endl;
	
	s1.append("hello ");  //append的中可存放变量名或变量值 
	cout<<"s1="<<s1<<endl;
	
	s2="world ";
	s1.append(s2,0,3);  //在s1末尾连接s2从0开始的连续3个字符 
	cout<<"s1="<<s1<<endl;
	
	s1.append(5,'@');  //在s1末尾连接3个@ 
	cout<<"s1="<<s1<<endl;  
	return 0;
}

运行结果如下:

注意:s1="mail "+"time";  //为错误写法,应改为 s1="mail ""time";(两个字符间无间隔)  

2.字符串的比较

注意字符串比较大小是一位一位比较

例:"121"<"21" ,"a121">"21"

  • 0
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Python 中字符串求子序列可以通过递归方法来实现。具体做法如下: 首先,编写一个函数 `find_subsequence(s, subsequence)`,其中 `s` 表示原始字符串,`subsequence` 表示当前找到的子序列。函数的作用是找到字符串 `s` 中的所有长度大于等于1的子序列。 在函数内部,分别考虑两种情况:当前字符 `s[0]` 参与子序列和不参与子序列。 1. 如果当前字符 `s[0]` 参与子序列,将其加入到 `subsequence` 中,并递归调用 `find_subsequence(s[1:], subsequence + s[0])`,即在剩余的字符串中寻找子序列。 2. 如果当前字符 `s[0]` 不参与子序列,直接递归调用 `find_subsequence(s[1:], subsequence)`,即在剩余的字符串中寻找子序列。 需要注意的是,递归调用 `find_subsequence` 时,需要传递更新后的 `s` 和 `subsequence`。 在递归的过程中,需要判断以下结束条件: 1. 当字符串 `s` 的长度为0时,表示已经遍历完了原始字符串,将 `subsequence` 加入到结果列表中。 2. 当字符串 `s` 的长度为1时,表示只剩下一个字符了,此时需要将当前字符加入到 `subsequence` 中,并将 `subsequence` 加入到结果列表中。 最后,在主程序中调用 `find_subsequence` 函数,并打印结果列表即可完成字符串求子序列的操作。 需要注意的是,这种方法可能会产生大量的重复子序列,因此可以使用集合(set)来存储结果,避免重复。另外,也可以对结果进行排序,使得结果按照一定的顺序输出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mailtimesh

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值