HihoCoder - 1082【字符串】

本文介绍了一个字符串替换的问题,主要内容是如何在输入的字符串中将特定的子串进行全局替换,并讨论了实现这一功能的具体代码细节。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

14184646038225.jpg

fjxmlhx不喜欢网上的 marshtomps 。所以他决定把所有的 “marshtomp”(名字不区分大小写) 改为 “fjxmlhx;

Input

输入包含多行,每行字符串不超过200的长度,一个单词不会一半出现在上一行,剩下的在下一行。直到文件结束(EOF)

Output

输出 替换之后的字符串。

Sample Input
The Marshtomp has seen it all before.
marshTomp is beaten by fjxmlhx!
AmarshtompB
Sample Output
The fjxmlhx has seen it all before.
fjxmlhx is beaten by fjxmlhx!

AfjxmlhxB

这道题的输出着实让我恶心了一番,用printf输出总是在空格的时候换行,弄了半天还是没有解决掉,后来结束后才想起来有putchar输出

思路大致就是碰到啊marshtomp就跳过输出fjxmlhx,注意要i+8

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
char s[201];
int main(){
    //char string1[10000010];
    while(gets(s)){
        int len=strlen(s);
        for(int i=0;s[i]!='\0';i++){
            if((s[i]=='m'||s[i]=='M')&&(s[i+1]=='a'||s[i+1]=='A')
               &&(s[i+2]=='r'||s[i+2]=='R')&&(s[i+3]=='s'||s[i+3]=='S')
               &&(s[i+4]=='h'||s[i+4]=='H')&&(s[i+5]=='t'||s[i+5]=='T')
               &&(s[i+6]=='o'||s[i+6]=='O')&&(s[i+7]=='m'||s[i+7]=='M')
               &&(s[i+8]=='p'||s[i+8]=='P')){
                printf("fjxmlhx");
                i=i+8;
               }
               else{
                putchar(s[i]);
               }
        }
        printf("\n");
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值