답안 #855719

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
855719 2023-10-01T17:06:21 Z vjudge1 Zamjena (COCI18_zamjena) C++17
70 / 70
449 ms 8016 KB
#pragma GCC optimize("unroll-loops", "O3")

//author: Ahmet Alp Orakci
#include <bits/stdc++.h>
using namespace std;
using i64 = long long;

bool check(string &a) {
    bool ans = true;
    for(char &ch : a) {
        ans &= ('0' <= ch && ch <= '9');
        if(!ans) 
            return 0;
    }

    return ans;
}

#define ONLINE_JUDGE
void solve() {
    int n;
    cin >> n;

    vector <string> a(n +1), b(n +1);
    for(int i = 1; i <= n; i++)
        cin >> a[i];
    for(int i = 1; i <= n; i++) 
        cin >> b[i];

    map <string, string> mp;

    vector <bool> vis(n +1);

    bool ans = true;
    for(int it = 1; it <= 100; it++) {
        for(int i = 1; i <= n; i++) {
            if(vis[i]) {
                continue;
            }

            if(check(a[i])) {
                if(check(b[i])) {
                    if(a[i] != b[i]) {
                        return cout << "NE", void();
                    }
                } else {
                    if(mp.count(b[i])) {
                        if(mp[b[i]] != a[i]) {
                            return cout << "NE", void();
                        } 
                    } else {
                        mp[b[i]] = a[i];
                    }
                }
                vis[i] = true;
            } else if(check(b[i])) {
                swap(a[i], b[i]);
                if(check(b[i])) {
                    if(a[i] != b[i]) {
                        return cout << "NE", void();
                    }
                } else {
                    if(mp.count(b[i])) {
                        if(mp[b[i]] != a[i]) {
                            return cout << "NE", void();
                        } 
                    } else {
                        mp[b[i]] = a[i];
                    }
                }
                vis[i] = true;

                swap(a[i], b[i]);
            }
        }

        for(int i = 1; i <= n; i++) {
            if(vis[i])
                continue;
            
            if(mp.count(a[i])) {
                a[i] = mp[a[i]];
            }

            if(mp.count(b[i])) {
                b[i] = mp[b[i]];
            }
        }
    }

    cout << "DA";

    return;
}

signed main() {
    #ifndef ONLINE_JUDGE
        freopen(".in", "r", stdin);
        freopen(".out", "w", stdout);
    #endif

    ios_base::sync_with_stdio(false);
    cin.tie(NULL); cout.tie(NULL);

    int t = 1; //cin >> t;
    for(int i = 1; i <= t; i++) {
        solve();
    }

    return 0;
}

Compilation message

zamjena.cpp: In function 'void solve()':
zamjena.cpp:34:10: warning: unused variable 'ans' [-Wunused-variable]
   34 |     bool ans = true;
      |          ^~~
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 344 KB Output is correct
2 Correct 0 ms 348 KB Output is correct
3 Correct 0 ms 348 KB Output is correct
4 Correct 0 ms 348 KB Output is correct
5 Correct 0 ms 348 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 348 KB Output is correct
2 Correct 0 ms 348 KB Output is correct
3 Correct 0 ms 348 KB Output is correct
4 Correct 0 ms 348 KB Output is correct
5 Correct 0 ms 348 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 348 KB Output is correct
2 Correct 0 ms 348 KB Output is correct
3 Correct 0 ms 348 KB Output is correct
4 Correct 0 ms 348 KB Output is correct
5 Correct 0 ms 348 KB Output is correct
6 Correct 0 ms 344 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 348 KB Output is correct
2 Correct 3 ms 348 KB Output is correct
3 Correct 2 ms 604 KB Output is correct
4 Correct 2 ms 604 KB Output is correct
5 Correct 9 ms 860 KB Output is correct
6 Correct 2 ms 604 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 5 ms 1368 KB Output is correct
2 Correct 84 ms 3024 KB Output is correct
3 Correct 23 ms 2392 KB Output is correct
4 Correct 27 ms 4700 KB Output is correct
5 Correct 449 ms 8016 KB Output is correct
6 Correct 230 ms 5456 KB Output is correct