uva_10115-Automatic Editing

来源:岁月联盟 编辑:exp 时间:2012-11-09
[cpp] 
/**本题含义是将前一个串转化为后一个串,当前一个串
 *完全找不到后,再去比较下一个串,直到所有串被替换完毕
 */ 
#include <cstdio> 
#include <iostream> 
#include <cstring> 
using namespace std; 
 
#define MAX 256 
 
//替换 
void replace(char *a, char *b, int pos) { 
    for(int i=0; i<strlen(a); i++) { 
        b[pos++] = a[i]; 
    } 

 
//查找子串 
int findSon(char *s1, char *s2, int &start, int &end) { 
    int j, i1; 
    for(int i=0; i<strlen(s2); i++) { 
        i1 = i; 
        for(j=0; j<strlen(s1); j++) { 
            if(s1[j]!=s2[i1++]) break; 
        } 
        if(j==strlen(s1)) { 
            start = i; end = i+j-1; return 1; 
        } 
    } 
    return 0; 

 
 
int main(int argc, char const *argv[]) { 
    int cas, start, end, len, flag; 
    char data[MAX]; 
    char word[MAX][MAX]; 
    while(cin>>cas,cas!=0) { 
        getchar(); 
        for(int i=0; i<2*cas; i+=2) { 
            gets(word[i]); 
            gets(word[i+1]); 
        } 
        gets(data); 
        for(int i=0; i<2*cas; i+=2) { 
            flag = 1; 
            while(flag) { 
                flag = findSon(word[i], data, start, end); 
                len = strlen(word[i])-strlen(word[i+1]); 
                //flag标识是否还存在可替换的串,下面代码为字符串替换,没有使用库函数 
                if(flag) { 
                    if(len<0) { 
                        len = -len; 
                        for(int i=strlen(data); i>end; i--) { 
                            data[i+len] = data[i]; 
                        } 
                    } else if(len>0) { 
                        for(int i=end-len+1; i<strlen(data); i++) { 
                            data[i] = data[i+len]; 
                        } 
                    } 
                    replace(word[i+1], data, start); 
                } 
            } 
 
        } 
        puts(data); 
    } 
    return 0;