답안 #948203

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
948203 2024-03-17T21:42:02 Z rainboy Walk (POI13_spa) C
36 / 100
2676 ms 262144 KB
/* https://oi.edu.pl/static/attachment/20140306/oi20.pdf */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
#define M	5000000
#define N_	5000001
#define L	60
#define MD	0x7fffffff
 
long long min(long long a, long long b) { return a < b ? a : b; }
long long max(long long a, long long b) { return a > b ? a : b; }
 
int X = 123454321;
 
int k;
 
long long parse() {
	static char cc[L + 1];
	int h;
	long long x;
 
	scanf("%s", cc);
	x = 0;
	for (h = 0; h < k; h++)
		if (cc[h] == '1')
			x |= 1LL << h;
	return x;
}
 
long long *ek[M]; int eo[M];
char *ev[M];

int hash(long long k) {
	int kl = k / MD, kr = k % MD;

	return ((long long) kl * X % MD + kr) * X % MD % M;
}

int ht_add(long long k, int v) {
	int h = hash(k), o;

	for (o = eo[h]; o--; )
		if (ek[h][o] == k) {
			if (ev[h][o] == (v ^ 1)) {
				printf("TAK\n");
				exit(0);
			}
			return 0;
		}
	o = eo[h]++;
	if (o == 0) {
		ek[h] = (long long *) malloc(2 * sizeof *ek[h]);
		ev[h] = (char *) malloc(2 * sizeof *ev[h]);
	} else if (o >= 2 && (o & o - 1) == 0) {
		ek[h] = (long long *) realloc(ek[h], o * 2 * sizeof *ek[h]);
		ev[h] = (char *) realloc(ev[h], o * 2 * sizeof *ev[h]);
	}
	ek[h][o] = k, ev[h][o] = v;
	return 1;
}

int bfs(long long s, int cnt_, int v) {
	static long long qu[N_];
	int cnt, g, h;
	long long b, b_;

	cnt = 0;
	ht_add(s, v), qu[cnt++] = s;
	for (g = 0; g < cnt; g++) {
		b = qu[g];
		for (h = 0; h < k; h++) {
			b_ = b ^ 1LL << h;
			if (ht_add(b_, v)) {
				qu[cnt++] = b_;
				if (cnt == cnt_)
					return 1;
			}
		}
	}
	return 0;
}

int main() {
	int n, i;
	long long s, t;
 
	scanf("%d%d", &k, &n), s = parse(), t = parse();
	if (s == t) {
		printf("TAK\n");
		return 0;
	}
	for (i = 0; i < n; i++)
		ht_add(parse(), -1);
	ht_add(s, 0), ht_add(t, 1);
	printf(bfs(s, n * k + 1, 0) && bfs(t, n * k + 1, 1) ? "TAK\n" : "NIE\n");
	return 0;
}

Compilation message

spa.c: In function 'ht_add':
spa.c:55:30: warning: suggest parentheses around '-' in operand of '&' [-Wparentheses]
   55 |  } else if (o >= 2 && (o & o - 1) == 0) {
      |                            ~~^~~
spa.c: In function 'parse':
spa.c:23:2: warning: ignoring return value of 'scanf' declared with attribute 'warn_unused_result' [-Wunused-result]
   23 |  scanf("%s", cc);
      |  ^~~~~~~~~~~~~~~
spa.c: In function 'main':
spa.c:88:2: warning: ignoring return value of 'scanf' declared with attribute 'warn_unused_result' [-Wunused-result]
   88 |  scanf("%d%d", &k, &n), s = parse(), t = parse();
      |  ^~~~~~~~~~~~~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Correct 23 ms 87120 KB Output is correct
2 Correct 13 ms 85756 KB Output is correct
3 Correct 14 ms 86620 KB Output is correct
4 Correct 25 ms 100692 KB Output is correct
5 Correct 25 ms 100696 KB Output is correct
6 Correct 0 ms 2396 KB Output is correct
7 Correct 1 ms 8540 KB Output is correct
8 Correct 2 ms 16728 KB Output is correct
9 Correct 2 ms 16732 KB Output is correct
10 Correct 3 ms 16732 KB Output is correct
11 Correct 117 ms 113744 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 154 ms 116052 KB Output is correct
2 Correct 272 ms 117440 KB Output is correct
3 Runtime error 2676 ms 262144 KB Execution killed with signal 9
4 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 13 ms 85592 KB Output is correct
2 Correct 79 ms 108856 KB Output is correct
3 Correct 146 ms 117176 KB Output is correct
4 Correct 30 ms 102488 KB Output is correct
5 Correct 30 ms 102508 KB Output is correct
6 Correct 14 ms 89176 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 22 ms 91996 KB Output is correct
2 Correct 12 ms 84432 KB Output is correct
3 Correct 69 ms 111708 KB Output is correct
4 Correct 103 ms 118356 KB Output is correct
5 Correct 97 ms 118608 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 94 ms 107604 KB Output is correct
2 Runtime error 1528 ms 262144 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 98 ms 106068 KB Output is correct
2 Correct 549 ms 178516 KB Output is correct
3 Correct 1081 ms 233036 KB Output is correct
4 Runtime error 1340 ms 262144 KB Execution killed with signal 9
5 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 143 ms 112536 KB Output is correct
2 Runtime error 2135 ms 262144 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 137 ms 111960 KB Output is correct
2 Correct 83 ms 105264 KB Output is correct
3 Correct 1307 ms 225448 KB Output is correct
4 Correct 91 ms 108008 KB Output is correct
5 Runtime error 1989 ms 262144 KB Execution killed with signal 9
6 Halted 0 ms 0 KB -