c++中字符串翻转的方法,用于刷题

1.使用算法头文件中的reserve

#include <iostream>
#include <string>
#include <algorithm>
using namespace std;

int main()
{
    string s = "hello";

    reverse(s.begin(),s.end());

    cout<<s<<endl;

    return 0;
}

 2.算法实例:

大数加法

描述

以字符串的形式读入两个数字,编写一个函数计算它们的和,以字符串形式返回。
(字符串长度不大于100000,保证字符串仅由'0'~'9'这10种字符组成)
 
 
示例1
输入:

"1","99"

返回值:

"100"

说明:

1+99=100 

 

算法思想:

//算法思想:从后向前遍历字符串,同时对应位的字符相加,同时将每次进位保存在af中,将新生成的字符放入u的后面,最后在将字符串倒转即可   就是模拟加法
//关键点:字符->整数:-'0'或者-48
//整数->字符:+'0'或者+48

 

算法代码:c++

 

class Solution {
public:
string solve(string s,string t)
{
    int af=0;    //进位位
    string u;
    int a=s.length(),b=t.length();    //求字符串长度
    while (a-->0 && b-->0)      
    {
        int x=s.at(a)-'0';        //将字符串中的字符变为整数
        int y=t.at(b)-'0';int z=(x+y+af)%10;    //本位结果
        af =(x+y+af)/10;     //进位的值
        z=z+'0';          //整数变为字符
        u.push_back(z);      //将字符加入字符串的末尾,现在的字符串是倒转的
    }while (a-->0)        
    {
        int x=s.at(a)-'0';
        int z=(x+af)%10;
        af=(x+af)/10;
        z=z+'0';
        u.push_back(z);
    }
    while (b-->0)
    {
        int y=t.at(b)-'0';
        int z=(y+af)%10;
        af=(af+y)/10;
        z=z+'0';
        u.push_back(z);
    }
    if (af>0)
        u.push_back(af+'0');
    reverse(u.begin(),u.end());  //颠倒字符串方法,在算法头文件中
    return u;
}
};

 

 

 

posted @ 2021-07-08 00:24  nanfengnan  阅读(203)  评论(0编辑  收藏  举报