使用迭代器 字符串插入

編程題#5:字符串插入

注意: 總時間限制: 1000ms 內存限制: 65536kB、

描述

有兩個字符串str和substr,str的字符個數不超過10,substr的字符個數爲3。(字符個數不包括字符串結尾處的'\0'。)將substr插入到str中ASCII碼最大的那個字符後面,若有多個最大則只考慮第一個。

輸入

輸入包括若干行每一行爲一組測試數據,格式爲

str substr

輸出

對於每一組測試數據,輸出插入之後的字符串。

樣例輸入

1:    abcab eee

2:   12343 555

樣例輸出

1:abceeeab

2:12345553

提示

這題有多組輸入,請參照第二題的提示依次讀入和處理每一組數據。

如果使用了字符串函數,比如strlen,請包含cstring頭文件 #include <cstring>。

有兩種方法,可以跑出來。

使用string下標

#include<iostream>
using namespace std;
int main(){
    string s1,s2;
    while(cin >> s1 >>s2){
        int index = 0;
        int len = s1.size();
        for(auto i = 0;i != len ;++i){
            if(s1[i] > s1[index])
                index = i;
        }
        for(int i = 0;i != index + 1;++i)
            cout << s1[i];
        cout << s2;
        for(int i = index + 1;i != len; ++i)
            cout << s1[i];
        cout <<endl;
    }
    return 0;
}

 

 最近在學迭代器,所以也使用了迭代器:代碼如下

#include<iostream>
#include<string>
using namespace std;
int main (){
    string s1(10,' '),s2(3 ,' ');
    while(cin >> s1 >> s2){
        int intex;
        for(auto i = s1.begin(),temp = s1.begin(); i != s1.end() && !isspace(*i);++i){
            if(*i > *temp){
                intex = i - s1.begin();
                temp = i;
            }
        }
        for(auto i = s1.begin();i != intex + s1.begin()+1;++i)
            cout << *i;
        cout << s2;
        for(auto i = intex + s1.begin()+1; i != s1.end();++i)
            cout << *i;
        cout<< endl;
    }
    return 0;
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章