답안 #211856

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
211856 2020-03-21T14:19:30 Z MarcoMeijer Vision Program (IOI19_vision) C++14
컴파일 오류
0 ms 0 KB
#include "vision.h"
#include <bits/stdc++.h>
using namespace std;

//macros
typedef long long ll;
typedef pair<int, int> ii;
typedef tuple<int, int, int> iii;
typedef vector<int> vi;
typedef vector<ii> vii;
typedef vector<iii> viii;
typedef vector<ll> vll;
#define REP(a,b,c) for(int a=int(b); a<int(c); a++)
#define RE(a,c) REP(a,0,c)
#define RE1(a,c) REP(a,1,c+1)
#define REI(a,b,c) REP(a,b,c+1)
#define REV(a,b,c) for(int a=int(c-1); a>=int(b); a--)
#define INF 1e9
#define pb push_back
#define fi first
#define se second
mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());

const int MX=500;

vi diagonal[2];
int dist[2][MX];
int h, w, k;
vi ans;

int getPos(int i, int j) {
	return j+i*w;
}
void construct_network(int H, int W, int K) {
	h=H, w=W, k=K;
	RE(i,w+h-1) {
		int x=i, y=0;
		if(x>=h) {
			y=x-h+1;
			x=h-1;
		}
		vi f;
		while(x>=0 && y<w) {
			f.pb(getPos(x,y));
			x--;
			y++;
		}
		diagonal[0].pb(add_and(f));
	}
	RE(i,w+h-1) {
		int x=0, y=w-i-1;
		if(y<0) {
			x=-y;
			y=0;
		}
		vi f;
		while(x>=0 && y>=0) {
			f.pb(getPos(x,y));
			x++;
			y++;
		}
		diagonal[1].pb(add_and(f));
	}
	RE(i,2) REP(j,1,k+1) {
		vi f;
		RE(l,diagonal[i].size()-j) {
			vi g;
			g.pb(diagonal[i][l]);
			g.pb(diagonal[i][l+j]);
			f.pb(add_and(g));
		}
		dist[i][j] = add_or(f);
	}
	RE(i,2) {
		vi f;
		f.pb(dist[i][k]);
		vi g;
		RE(j,k) g.pb(dist[!i][j]);
		f.pb(add_or(g));
		ans.pb(add_and(f));
	}
	add_or(ans[0], ans[1]);
}

Compilation message

vision.cpp: In function 'void construct_network(int, int, int)':
vision.cpp:82:23: error: could not convert 'ans.std::vector<int>::operator[](0)' from '__gnu_cxx::__alloc_traits<std::allocator<int> >::value_type {aka int}' to 'std::vector<int>'
  add_or(ans[0], ans[1]);
                       ^