24h購物| | PChome| 登入
2013-06-26 14:24:04| 人氣518| 回應0 | 上一篇 | 下一篇

[UVA] 11058 - Encoding

推薦 0 收藏 0 轉貼0 訂閱站台

Problem C - Encoding

Time Limit: 1 second

You want to encode a string changing its letters. For each letter in the original string, where a letter is in the range a-z, you should replace it according to some encoding strategy. But that is not all! Your encoding strategy can also change and depends on the current position of the original string that you are analyzing.

In the beginning, there is an initial encoding strategy, specifying how you should replace the letters of the original string. At each step you can also have some additional rules, specifying a new enconding strategy for some letter. If there is not a new encoding strategy for a letter you should keep the old one. For example, we can estabilish that every a in the original string should be replaced by b, then you should estabilish that every a that appears since position 4 of the original string should be replaced by c.

Input

There are several test cases. Each test case starts with a string S, you can assume that the length of S is at most 100. Then 26 lines will follow, specifying the encoding strategy for each letter, where the first line has the letter that should replace an a in the string S, the second line has the letter that should replace a b in the original string and so on.

After this, there is a line with an integer 0 ≤ R ≤ 1000 indicating the number of additional rules. Each one of the next R lines will have a rule, where each rule has the form P X Y, indicating that since position P ≥ 0 of the original string you should replace the letter X by Y. The first letter of a string is at position 0. You can assume that the initial position P of a rule in a test case is never less than the initial position of a previous rule in the same test case. If there are two rules for the same letter starting in the same position you should consider the rule that appears later in the input. There is a blank line after each test case and the input is finished by end of file (EOF).

Output

For each test case you must print the message: Case #N: The encoding string is E., where N is the number of the test case, starting from 1, and E is the string that you get after apply the set of encoding rules over the original string. After each test case you should print a blank line.

Sample Input

ufrn
t
o
w
k
q
z
f
n
y
i
c
m
s
j
n
r
g
l
d
s
u
s
g
y
e
u
10
0 q t
0 j f
1 v d
1 f d
1 r o
2 e p
2 v e
3 y p
3 t m
3 u k

Sample Output

Case #1: The encoding string is udoj.


Problem setter: Sérgio Queiroz de Medeiros

依序轉換字符, 對應表隨位置改變, 純模擬

但是如果有
10 m x
10 m y
以輸入時, 後者為主。

#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;
struct E {
    int p, idx;
    char x, y;
    bool operator<(const E &a) const {
        if(p != a.p)
            return p < a.p;
        return idx < a.idx;
    }
};
int main() {
    char s[105];
    int i, j, r, pos;
    E D[1005];
    int cases = 0;
    while(scanf("%s", &s) == 1) {
        char ascii[128], ss[10], pp[10], qq[10];
        for(i = 'a'; i <= 'z'; i++) {
            scanf("%s", ss);
            ascii[i] = ss[0];
        }
        scanf("%d", &r);
        for(i = 0; i < r; i++) {
            scanf("%d %s %s", &pos, pp, qq);
            D[i].p = pos, D[i].idx = i;
            D[i].x = pp[0], D[i].y = qq[0];
        }
        sort(D, D+r);
        int idx = 0;
        for(i = 0; s[i]; i++) {
            while(idx < r && D[idx].p <= i) {
                ascii[D[idx].x] = D[idx].y;
                idx++;
            }
            s[i] = ascii[s[i]];
        }
        printf("Case #%d: The encoding string is %s.\n\n", ++cases, s);
    }
    return 0;
}

台長: Morris
人氣(518) | 回應(0)| 推薦 (0)| 收藏 (0)| 轉寄
全站分類: 不分類 | 個人分類: UVA |
此分類下一篇:[UVA] 11004 - Changing Roadmap
此分類上一篇:[UVA][dp] 11008 - Antimatter Ray Clearcutting

是 (若未登入"個人新聞台帳號"則看不到回覆唷!)
* 請輸入識別碼:
請輸入圖片中算式的結果(可能為0) 
(有*為必填)
TOP
詳全文