UVA - 10115 Automatic Editing

UVA - 10115 Automatic Editing

题目大意:根据给出的替换规则替换字符串,要按照规则顺序,整个字符串都找不到后才能进行下一个规则。

解题思路:查找规则子串,标记在字符串中的头尾位置,创建一个临时数组,将替换后的串放入临时数组,接上尾部以后的原串,然后再将这个临时数组接到原串中标记的规则串头部。即原串 = a < b > c,b 替换后为 d,创建 temp = d,接入 c,再将 temp = d + c 接入 a,即 a + d + c,组合使用 strcpy 和 strcat 的技巧。

/* UVA - 10115 Automatic Editing*/
#include <cstdio>
#include <cstring>
int main () {
    int N;
    char a[1000][2][1000];
    char b[1000];
    scanf("%d",&N);
    int flag;
    while (N != 0 ) {
        getchar();
        for (int i = 0; i < N; i++) {
            gets(a[i][0]);
            gets(a[i][1]);
        }
        gets(b);
        char cc[1000];
        char *c = cc, *c2;
        for (int i = 0; i < N;) {
            memset(cc, 0, sizeof (cc));
            strcpy(c,a[i][1]);
            c2 = strstr(b, a[i][0]);
            if (c2 != NULL) {
                *c2 = '\0';
                strcat(c, c2+strlen(a[i][0]));
                strcat(b, c);
            }
            if ( c2 == NULL) i++; 
        }   
        printf("%s\n", b);  
        memset(a, 0, sizeof (a));
        memset(b, 0, sizeof (b));
        scanf("%d", &N);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值