50010. Word Editor
難度:2/51
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <assert.h>
char s[200500] = {'\0'};
char x[2], y[2];
char buf[200500] = {'\0'};
void replace(char x, char y){
for(int i = 0; s[i] != '\0'; i++){
if(s[i] == x) s[i] = y;
}
}
void _remove(char x){
int buf_size = 0;
for(int i = 0; s[i] != '\0'; i++){
if(s[i] != x){
buf[buf_size] = s[i];
buf_size++;
}
}
for(int i = 0; i < buf_size; i++){
s[i] = buf[i];
}
s[buf_size] = '\0';
}
void addhead(char x){
int size = 0;
for(int i = 0; s[i] != '\0'; i++){
buf[i] = s[i];
size++;
}
s[0] = x;
for(int i = 0; i < size; i++){
s[i + 1] = buf[i];
}
s[size + 1] = '\0';
}
void addtail(char x){
int size = strlen(s);
s[size] = x;
s[size + 1] = '\0';
}
int main(){
scanf("%s", s);
char cmd[20];
while(scanf("%s", cmd) != EOF){
if(strcmp(cmd, "end") == 0){
printf("%s\n", s);
break;
}
else if(strcmp(cmd, "replace") == 0){
scanf("%s %s", x, y);
replace(x[0], y[0]);
}
else if(strcmp(cmd, "remove") == 0){
scanf("%s", x);
_remove(x[0]);
}
else if(strcmp(cmd, "addhead") == 0){
scanf("%s", x);
addhead(x[0]);
}
else if(strcmp(cmd, "addtail") == 0){
scanf("%s", x);
addtail(x[0]);
}
else{
printf("invalid command %s\n", cmd);
break;
}
}
}