Submission #146330

# Submission time Handle Problem Language Result Execution time Memory
146330 2019-08-23T13:55:31 Z jwvg0425 Vision Program (IOI19_vision) C++17
0 / 100
5 ms 1396 KB
#include "vision.h"
#include <stdio.h>
#include <vector>
#include <queue>
#include <algorithm>
#include <iostream>
#include <string>
#include <bitset>
#include <map>
#include <set>
#include <tuple>
#include <string.h>
#include <math.h>
#include <random>
#include <functional>
#include <assert.h>
#include <math.h>
#define all(x) (x).begin(), (x).end()
#define xx first
#define yy second

using namespace std;

using i64 = long long int;
using ii = pair<int, int>;
using ii64 = pair<i64, i64>;

int h, w, k;

int cell(int x, int y)
{
	return y * w + x;
}

vector<int> allXCell(int y)
{
	vector<int> xs;

	for (int x = 0; x < w; x++)
		xs.push_back(cell(x, y));

	return xs;
}

vector<int> allYCell(int x)
{
	vector<int> ys;

	for (int y = 0; y < h; y++)
		ys.push_back(cell(x, y));

	return ys;
}

vector<int> range(int s, int e)
{
	vector<int> v;

	for (int i = s; i <= e; i++)
		v.push_back(i);

	return v;
}

int xcell(int x)
{
	return h * w + x;
}

int ycell(int y)
{
	return h * w + w + y;
}

int xd[205];
int yd[205];

void construct_network(int H, int W, int K) {
	h = H; w = W; k = K;

	for (int x = 0; x < W; x++)
		add_or(allYCell(x));

	for (int y = 0; y < H; y++)
		add_or(allXCell(y));

	xd[0] = add_xor(range(xcell(0), xcell(w - 1))); // x1 == x2 검사 셀
	yd[0] = add_xor(range(ycell(0), ycell(h - 1))); // y1 == y2 검사 셀

	for (int d = 1; d < W; d++)
	{
		vector<int> c;

		for (int x = 0; x < W - d; x++)
			c.push_back(add_and({ xcell(x), xcell(x + d) }));
		
		xd[d] = add_or(c);
	}

	for (int d = 1; d < H; d++)
	{
		vector<int> c;

		for (int y = 0; y < H - d; y++)
			c.push_back(add_and({ ycell(y), ycell(y + d) }));

		yd[d] = add_or(c);
	}

	vector<int> check;
	for (int xk = 0; xk <= k; xk++)
	{
		int yk = k - xk;

		check.push_back(add_and({ xd[xk], yd[yk] }));
	}

	add_or(check);
}
# Verdict Execution time Memory Grader output
1 Correct 2 ms 376 KB Output is correct
2 Incorrect 2 ms 256 KB on inputs (0, 0), (0, 1), expected 0, but computed 1
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 376 KB Output is correct
2 Incorrect 2 ms 256 KB on inputs (0, 0), (0, 1), expected 0, but computed 1
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 376 KB Output is correct
2 Incorrect 2 ms 256 KB on inputs (0, 0), (0, 1), expected 0, but computed 1
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 376 KB Output is correct
2 Incorrect 2 ms 256 KB on inputs (0, 0), (0, 1), expected 0, but computed 1
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 4 ms 1156 KB WA in grader: Too many instructions
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 256 KB Output is correct
2 Incorrect 2 ms 348 KB on inputs (0, 0), (0, 1), expected 0, but computed 1
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 5 ms 1396 KB WA in grader: Too many instructions
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 376 KB Output is correct
2 Incorrect 2 ms 256 KB on inputs (0, 0), (0, 1), expected 0, but computed 1
3 Halted 0 ms 0 KB -