編程題#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;
}