08:字符替换
-
题目链接→
NOI--ch0107--08 字符替换
总时间限制: 1000ms 内存限制: 65536kB
描述
把一个字符串中特定的字符全部用给定的字符替换,得到一个新的字符串。
输入
只有一行,由一个字符串和两个字符组成,中间用单个空格隔开。字符串是待替换的字符串,字符串长度
小于等于30个字符,且不含空格等空白符;
接下来一个字符为需要被替换的特定字符;
接下来一个字符为用于替换的给定字符。
输出
一行,即替换后的字符串。
样例输入
hello-how-are-you o O
样例输出
hellO-hOw-are-yOu
解题思路
【题意】
用特定字符替换字符串中的指定字符。
【类型】
字符串
【分析】
这道题有1个注意点:
1.题意明显,分析起来也容易,易错的是scanf的用法, scanf("%s %c %c",s,&c1,&c2);
不是scanf("%s %c %c",s,c1,c2);读入串s前无地址符&,但是读入单个字符c前有地址符&。
【时间复杂度&&优化】
O(n)
Source code
#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
int main() {
char s[31];
char c1,c2;
scanf("%s %c %c",s,&c1,&c2);
//不是scanf("%s %c %c",s,c1,c2);
for(int i=0;i<=strlen(s);i++){
if(s[i]==c1){
s[i]=c2;
}
}
printf("%s",s);
return 0;
}