//描述
//输入一个字符串,以回车结束(字符串长度<=100)。
//该字符串由若干个单词组成,单词之间用一个空格隔开,
//所有单词区分大小写。现需要将其中的某个单词替换成另一个单词,
//并输出替换之后的字符串。
//输入描述:
//每组数据输入包括3行,第1行是包含多个单词的字符串s,
//第2行是待替换的单词a(长度<=100),第3行是a将被替换的单词b(长度<=100)。
//s, a, b 最前面和最后面都没有空格。
//输出描述:
//每个测试数据输出只有 1 行, 将s中所有单词a替换成b之后的字符串。
#include <cstdio>
#include <iostream>
#include <cmath>
#include <algorithm>
#include <string>
using namespace std;
int main(){
    string str1,str2,str3,str4;
    while(getline(cin,str1)){
        getline(cin,str2);
        getline(cin,str3);
        str1=" "+str1+" ";
        str2=" "+str2+" ";
        str3=" "+str3+" ";
        while(str1.find(str2)!=string::npos){
            int pos=str1.find(str2);
            str1.erase(pos,str2.size());
            str1.insert(pos,str3);
        }
        cout<<str1.substr(1,str1.size())<<endl;
    }
}