Day08——字符串

替换数字

给定一个字符串 s,它包含小写字母和数字字符,请编写一个函数,将字符串中的字母字符保持不变,而将每个数字字符替换为number。 例如,对于输入字符串 "a1b2c3",函数应该将其转换为 "anumberbnumbercnumber"。

具体思路,视频讲解:代码随想录 (programmercarl.com)

思路:“双指针”

1,先一层for遍历一遍字符串,计算出其中数字的个数,也就是要被替换成“number”的个数。

2,替换后的字符串肯定要比原串要大,所以会涉及到字符串的扩容操作resize()。

3,双指针遍历,左指针指向原串最后一个元素,右指针指向扩充后串的最后一位。

        左右指针都向前移动,当左边指针移动检测到数字时,右边指针将依次输出“number”(倒序!!!)。

        当检测到字母时,左边的值赋给右边,直到左右指针相碰。

#include <iostream>

using namespace std;

int main(){
    string s;
    cin >> s;
    int left = s.size() - 1, right = 0;
    // 先数数,遍历有多个数字,用于扩充字符串
    int count = 0;
    for(int i = 0; s[i] != '\0'; i++){
        if(s[i] >= '0' && s[i] <= '9'){
            count++;
        }
    }
    s.resize(s.size() + count * 5); // c++扩充字符串
    right = s.size() - 1;  // 此时s已经扩充完了,新的大小
    // cout << left << " " << right << " ";
    
    // 双指针遍历s
    while(left != right){
    //while(left >= 0){
        if(s[left] >= '0' && s[left] <= '9'){
            s[right--] = 'r';
            s[right--] = 'e';
            s[right--] = 'b';
            s[right--] = 'm';
            s[right--] = 'u';
            s[right--] = 'n';
        }
        else{
            s[right--] = s[left];
        }
        left--;
    }
    cout << s << endl;
}

反转字符串

思路:也是双指针,不过每次遍历的跨度为2k,右指针和左指针的跨度为k

然后左右指针内的区域进行交换反转!

void swap(char* a, char* b){
    *a ^= *b;
    *b ^= *a;
    *a ^= *b;
}
// 不变的是:都要翻转前k个字符
class Solution {
public:
    string reverseStr(string s, int k) {
        int start = 0, end = 0;
        int len = s.size();
        for(int i = 0; i < len; i += (2 * k)){
            start = i;
            end = (i + k - 1) < len ? (i + k - 1) : (len - 1);
            while(start < end){  // 必须是< ,不能是!=
                swap(&s[start++], &s[end--]);
            }
        }
        return s;
    }
};

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值