手撕算法-知耻而后勇!

文章介绍了如何在C++中解决两个字符串问题:一是使用中心扩展法寻找给定字符串中的最长回文子串;二是实现字符串形式的非负整数相加,不依赖大整数库或转换为整数。此外,还提到可以扩展到其他进制的加法运算。

5、最长回文子串

给你一个字符串s,找到s中最长的回文子串。
如果字符串的反序与原始字符串相同,则该字符串称为回文字符串。
示例1:

  • 输入:s=“babad”
  • 输出:“bab"
  • 解释:”aba"同样是符合题意的答案

示例2

  • 输入:s=“cbbd”
  • 输出:“bb”

提示:

  • 1<=s.length<=1000
  • s仅由数字和英文字母组成

方法一:中心扩展法,写法一

class Solution{
public:
	string longestPalindrome(string s){
		int n=s.size();
		if(n<2) return s;
		string max_s;//存放最大子串
		for(int i=0;i<n-1;++i){
			if(i+1<n&&s[i+1]==s[i])//当回文串是偶数长度
			{
				int l=i,r=i+1;
				while(l>=0&&r<n){//防越界
					if(s[l]!=s[r])//回文终止
					{
						break;
					}
					++r,--l;
				}
				if(r-l-1>max_s.size()) max_s=s.substr(l+1,r-l-1);
			}
			if(i>0&&s[i-1]==s[i+1])//当回文串的长度为奇数
			{
				int l=i-1,r=i+1;
				while(l>=0&&r<n)//防越界
				{
					if(s[l]!=s[r])//回文终止
					{
						break;
					}
					++r,--l;
				}
				if(r-l-1>max_s.size()) max_s=s.substr(l+1,r-l-1);
			}	
		}
		return max_s.size()==0?max_s+s[0]:max_s;
	}
};

415、字符串相加
给定两个字符串形式的非负整数num1和num2,计算它们的和并同样以字符串形式返回。
你不能使用任何内建的用于处理大整数的库,也不能直接将输入的字符串转换为整数形式
示例1:

  • 输入:num1=“11”,num2=“123”
  • 输出:“134”
class Solution{
public:
	string addStrings(string num1,string num2){
		int i=num1.size()-1,j=num2.size()-1,add=0;
		string ans="";
		while(i>=0||j>=0||add!=0){
			int x=i>=0?num1[i]-'0':0;
			int y=j>=0?num2[j]-'0':0;
			int result=x+y+add;
			ans.push_back('0'+result%10);
			add=result/10;
			j-=1;
			i-=1;
		}
		reverse(ans.begin(),ans.end());
		return ans;
	}
};

拓展,字符串实现其他进制加法,如八进制!

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值