https://codeforc.es/contest/1697/problem/C
因为规则中,两种字符串变换都与‘b’有关,所以我们根据b的位置来进行考虑;
先去掉所有的’b’,如果两字符串不相等就“NO”;
否则通过‘b’在a,b串中的位置,如果posa>posb,那么他们之间如果出现’a’就说明不可能
如果posb<posa,那么他们之间如果出现’c’说明不可能
 1 # include<iostream>
 2 # include<bits/stdc++.h>
 3 using namespace std;
 4 const int N = 3e5 + 10;
 5 #define int long long
 6 # define endl "/n"
 7 int suma[N], sumc[N];
 8 char a[N], b[N];
 9 char newa[N], newb[N];
10 int posa[N], posb[N];
11 void solve() {
12     int n;
13     cin >> n;
14     cin >> a + 1 >> b + 1;
15     int cnt1 = 0, cnt2 = 0;
16     for (int i = 1; i <= n; ++i) {
17         if (a[i] == 'a') suma[i] = suma[i - 1] + 1;
18         else suma[i] = suma[i - 1];
19         if (a[i] == 'c') sumc[i] = sumc[i - 1] + 1;
20         else sumc[i] = sumc[i - 1];
21         if (a[i] != 'b') newa[++cnt1] = a[i];
22         if (b[i] != 'b') newb[++cnt2] = b[i];
23     }
24 
25     if (cnt1 != cnt2) {
26         cout << "NO" << endl;
27         return;
28     }
29     for (int i = 1; i <= cnt1; ++i) {
30         if (newa[i] != newb[i]) {
31             cout << "NO" << endl;
32             return;
33         }
34     }
35     cnt1 = 0, cnt2  = 0;
36     for (int i = 1; i <= n; ++i) {
37         if (a[i] == 'b') posa[++cnt1] = i;
38         if (b[i] == 'b') posb[++cnt2] = i;
39     }
40     if (cnt1 != cnt2) {
41         cout << "NO" << endl;
42         return;
43     }
44     for (int i = 1; i <= cnt1; ++i) {
45         int x = posa[i], y = posb[i];
46         if (x < y) {
47             if (suma[y] - suma[x - 1] != 0) /*前缀和判断a的位置*/
         {
48                 cout << "NO" << endl;
49                 return;
50             }
51         }
52         if (x > y) {
53             if (sumc[x] - sumc[y - 1] != 0) {
54                 cout << "NO" << endl;
55                 return;
56             }
57         }
58 
59     }
60     cout << "YES" << endl;
61 }
62 int tt;
63 signed main() {
64     ios::sync_with_stdio(false);
65     cin.tie(0);
66     cout.tie(0);
67 
68     cin >> tt;
69 
70     while (tt--)solve();
71     return 0;
72 }
73 /*
74 
75 */
主要是通过前缀和来判断两个pos之间是否存在’a’或者’c’的操作
原创文章,作者:1402239773,如若转载,请注明出处:https://blog.ytso.com/tech/pnotes/271862.html
