답안 #980980

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
980980 2024-05-12T16:51:47 Z emad234 Paint By Numbers (IOI16_paint) C++17
7 / 100
1 ms 2396 KB
#include "paint.h"
#include <bits/stdc++.h>
#define ll long long
#define F first
#define S second
#define pii pair<ll, ll>
const ll mod = 1e9 + 7;
const ll mxN = 3e5 + 2;
using namespace std;
bool dpP[200010][110][2], dpS[200010][110][2];
int prfx[200010], suff[200010];
int a[200010], b[200010];
string solve_puzzle(string s, vector<int> c)
{
    int n = s.size(), k = c.size();
    string s1 = "#";
    s1 += s;
    s = s1;
    vector<int> c1;
    c1.push_back(-1);
    for (auto x : c)
        c1.push_back(x);
    c = c1;
    for (int i = 1; i <= n; i++)
    {
        prfx[i] = prfx[i - 1] + (s[i] == '_');
    }
    dpP[0][0][0] = 1;
    dpS[n + 1][k + 1][0] = 1;
    for (int j = 0; j <= k; j++)
    {
        for (int i = 1; i <= n; i++)
        {
            if (s[i] != 'X')
            {
                dpP[i][j][0] = dpP[i - 1][j][0];
            }
            if (s[i] != '_' && j)
            {
                if (i >= c[j])
                {
                    if (prfx[i] == prfx[i - c[j]])
                    {
                        if (j == 1)
                            dpP[i][j][1] = dpP[i - c[j]][j - 1][0];
                        else if (i > c[j])
                            dpP[i][j][1] = dpP[i - c[j] - 1][j - 1][0];
                    }
                }
            }
            dpP[i][j][0] = max(dpP[i][j][0], dpP[i][j][1]);
            // cout << dpP[i][j][1] << ' ';
        }
        // cout << '\n';
    }
    // cout<<'\n';
    for (int i = n; i; i--)
    {
        suff[i] = suff[i + 1] + (s[i] == '_');
    }
    for (int j = k + 1; j; j--)
    {
        for (int i = n; i; i--)
        {
            if (s[i] != 'X')
            {
                dpS[i][j][0] = dpS[i + 1][j][0];
            }
            if (s[i] != '_' && j != k + 1)
            {
                if (n - i + 1 >= c[j])
                {
                    if (suff[i] == suff[i + c[j]])
                    {
                        if (j == k)
                            dpS[i][j][1] = dpS[i + c[j]][j + 1][0];
                        else
                            dpS[i][j][1] = dpS[i + c[j] + 1][j + 1][0];
                        // cout<<i<<' '<<j<<' '<<dpS[i][j][1]<<'\n';
                    }
                }
            }
            dpS[i][j][0] = max(dpS[i][j][0], dpS[i][j][1]);
            // cout << dpS[i][j][0] << ' ';
        }
        // cout<<'\n';
    }
    // cout<<'\n';
    for (int i = 1; i <= n; i++)
    {
        for (int j = 1; j <= k + 1; j++)
        {
            if (j != k + 1 && ((dpP[i][j][1] && dpS[i + 1][j + 1][0]) && (i == n || s[i + 1] != 'X')))
            {
                a[i - c[j] + 1] += 1;
                a[i + 1] += -1;
            }
            if (j != k + 1 && ((dpP[i - 1][j - 1][0] && dpS[i][j][1]) && (i == 1 || s[i - 1] != 'X')))
            {
                a[i] += 1;
                a[i + c[j]] += -1;
            }
            if (dpP[i - 1][j - 1][0] && dpS[i + 1][j][0])
                b[i] = 1;
        }
    }
    // cout<<a[4]<<'\n';
    for (int i = 1; i <= n; i++)
    {
        a[i] += a[i - 1];
        // cout<<a[i]<<' ';
    }
    // cout<<'\n';
    string ans;
    for (int i = 1; i <= n; i++)
    {
        char ch;
        if (s[i] != '.')
        {
            ans += s[i];
            continue;
        }
        if (a[i] && b[i])
            ch = '?';
        else if (a[i])
            ch = 'X';
        else if (b[i])
            ch = '_';
        ans += ch;
    }
    // cout<<ans<<' '<<"TEST";
    return ans;
}
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 2396 KB n = 13, m = 1
2 Correct 1 ms 2396 KB n = 18, m = 1
3 Correct 1 ms 2396 KB n = 17, m = 1
4 Correct 1 ms 2396 KB n = 1, m = 1
5 Correct 1 ms 2396 KB n = 20, m = 1
6 Correct 1 ms 2396 KB n = 20, m = 1
7 Correct 1 ms 2396 KB n = 20, m = 1
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 2396 KB n = 13, m = 1
2 Correct 1 ms 2396 KB n = 18, m = 1
3 Correct 1 ms 2396 KB n = 17, m = 1
4 Correct 1 ms 2396 KB n = 1, m = 1
5 Correct 1 ms 2396 KB n = 20, m = 1
6 Correct 1 ms 2396 KB n = 20, m = 1
7 Correct 1 ms 2396 KB n = 20, m = 1
8 Correct 1 ms 2396 KB n = 20, m = 5
9 Incorrect 1 ms 2396 KB char #5 differ - expected: '_', found: '?'
10 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 2396 KB n = 13, m = 1
2 Correct 1 ms 2396 KB n = 18, m = 1
3 Correct 1 ms 2396 KB n = 17, m = 1
4 Correct 1 ms 2396 KB n = 1, m = 1
5 Correct 1 ms 2396 KB n = 20, m = 1
6 Correct 1 ms 2396 KB n = 20, m = 1
7 Correct 1 ms 2396 KB n = 20, m = 1
8 Correct 1 ms 2396 KB n = 20, m = 5
9 Incorrect 1 ms 2396 KB char #5 differ - expected: '_', found: '?'
10 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 2396 KB n = 13, m = 1
2 Correct 1 ms 2396 KB n = 18, m = 1
3 Correct 1 ms 2396 KB n = 17, m = 1
4 Correct 1 ms 2396 KB n = 1, m = 1
5 Correct 1 ms 2396 KB n = 20, m = 1
6 Correct 1 ms 2396 KB n = 20, m = 1
7 Correct 1 ms 2396 KB n = 20, m = 1
8 Correct 1 ms 2396 KB n = 20, m = 5
9 Incorrect 1 ms 2396 KB char #5 differ - expected: '_', found: '?'
10 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 2396 KB n = 13, m = 1
2 Correct 1 ms 2396 KB n = 18, m = 1
3 Correct 1 ms 2396 KB n = 17, m = 1
4 Correct 1 ms 2396 KB n = 1, m = 1
5 Correct 1 ms 2396 KB n = 20, m = 1
6 Correct 1 ms 2396 KB n = 20, m = 1
7 Correct 1 ms 2396 KB n = 20, m = 1
8 Correct 1 ms 2396 KB n = 20, m = 5
9 Incorrect 1 ms 2396 KB char #5 differ - expected: '_', found: '?'
10 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 2396 KB n = 13, m = 1
2 Correct 1 ms 2396 KB n = 18, m = 1
3 Correct 1 ms 2396 KB n = 17, m = 1
4 Correct 1 ms 2396 KB n = 1, m = 1
5 Correct 1 ms 2396 KB n = 20, m = 1
6 Correct 1 ms 2396 KB n = 20, m = 1
7 Correct 1 ms 2396 KB n = 20, m = 1
8 Correct 1 ms 2396 KB n = 20, m = 5
9 Incorrect 1 ms 2396 KB char #5 differ - expected: '_', found: '?'
10 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 2396 KB n = 13, m = 1
2 Correct 1 ms 2396 KB n = 18, m = 1
3 Correct 1 ms 2396 KB n = 17, m = 1
4 Correct 1 ms 2396 KB n = 1, m = 1
5 Correct 1 ms 2396 KB n = 20, m = 1
6 Correct 1 ms 2396 KB n = 20, m = 1
7 Correct 1 ms 2396 KB n = 20, m = 1
8 Correct 1 ms 2396 KB n = 20, m = 5
9 Incorrect 1 ms 2396 KB char #5 differ - expected: '_', found: '?'
10 Halted 0 ms 0 KB -