Submission #1114461

# Submission time Handle Problem Language Result Execution time Memory
1114461 2024-11-18T23:41:07 Z sunboi Xylophone (JOI18_xylophone) C++17
Compilation error
0 ms 0 KB
#include <cstdio>
#include <cstdlib>
#include <iostream>
#include <vector>
using namespace std;
#include "xylophone.h"
 
static int A[5000];
 
 
void solve(int N){
    int n = N;
    int i = 1, fin = n;
    while(i < fin){
        int m = (i + fin) / 2;
        if (query(m, n) == n - 1){
            i = m + 1; 
        }else fin = m;
    }
    i--;
    int reference = i;
    vector<int> a(n + 1), vis(n + 1);
    int x = query(i, i + 1);
    a[i] = 1;
    a[i + 1] = x + 1;
    i += 2;
    vis[1] = = vis[x + 1] = 1;
    int last = x;
    
    for (; i <= n; i++){
        int mn = min(a[i - 1], a[i - 2]);
        int uno = query(i - 1, i);
        
        if (a[i - 1] + uno > n) a[i] = a[i - 1] - uno;
        else if (a[i - 1] + uno < 1) a[i] = a[i - 1] + uno;
        else if (vis[a[i - 1] + uno]) a[i] = a[i - 1] - uno;
        else if (vis[a[i - 1] - uno]) a[i] = a[i - 1] + uno;
        else{
            int dos = query(i - 2, i);
        
            if (dos > last){
                if (dos == uno){
                    if (a[i - 1] == mn) a[i] = a[i - 1] + uno;
                    else a[i] = a[i - 1] - uno;
                }else{
                    if (a[i - 2] == mn) a[i] = a[i - 2] + dos;
                    else  a[i] = a[i - 2] - dos;
                }
            }else{
                if (a[i - 1] == mn) a[i] = a[i - 1] + uno;
                else a[i] = a[i - 1] - uno;
            }
        }
        vis[a[i]] = 1;
        last = uno;
    }
    i = reference;
	if (i > 1){
		x = query(i - 1, i);
		a[i - 1] = 1 + x;
		vis[1 + x] = 1;
		last = x;
		i -= 2;
		for (; i >= 1; i--){
			int mn = min(a[i + 1], a[i + 2]);
			int uno = query(i, i + 1);
			if (a[i + 1] + uno > n) a[i] = a[i + 1] - uno;
            else if (a[i + 1] + uno < 1) a[i] = a[i + 1] + uno;
            else if (vis[a[i + 1] + uno]) a[i] = a[i + 1] - uno;
            else if (vis[a[i + 1] - uno]) a[i] = a[i + 1] + uno;
			else{
			    int dos = query(i, i + 2);
			    if (dos > last){
    				if (dos == uno){
    					if (a[i + 1] == mn) a[i] = a[i + 1] + uno;
    					else a[i] = a[i + 1] - uno;
    				}else{
    					if (a[i + 2] == mn) a[i] = a[i + 2] + dos;
    					else  a[i] = a[i + 2] - dos;
    				}
    			}else{
    				if (a[i + 1] == mn) a[i] = a[i + 1] + uno;
    				else a[i] = a[i + 1] - uno;
    			}
			}
			
			vis[a[i]] = 1;
			last = uno;
		}
	}
    for(int i = 1;i<=n;i++) answer(i, a[i]);
	return;
}

Compilation message

xylophone.cpp: In function 'void solve(int)':
xylophone.cpp:27:14: error: expected primary-expression before '=' token
   27 |     vis[1] = = vis[x + 1] = 1;
      |              ^
xylophone.cpp: At global scope:
xylophone.cpp:8:12: warning: 'A' defined but not used [-Wunused-variable]
    8 | static int A[5000];
      |            ^