답안 #948204

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
948204 2024-03-17T21:42:31 Z rainboy Walk (POI13_spa) C
49 / 100
3516 ms 262144 KB
/* https://oi.edu.pl/static/attachment/20140306/oi20.pdf */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
#define M	4000000
#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 24 ms 68688 KB Output is correct
2 Correct 14 ms 69852 KB Output is correct
3 Correct 12 ms 72292 KB Output is correct
4 Correct 21 ms 80220 KB Output is correct
5 Correct 27 ms 80212 KB Output is correct
6 Correct 1 ms 2392 KB Output is correct
7 Correct 1 ms 8540 KB Output is correct
8 Correct 2 ms 16732 KB Output is correct
9 Correct 2 ms 16732 KB Output is correct
10 Correct 2 ms 16732 KB Output is correct
11 Correct 124 ms 93364 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 158 ms 95532 KB Output is correct
2 Correct 241 ms 99080 KB Output is correct
3 Runtime error 3516 ms 262144 KB Execution killed with signal 9
4 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 10 ms 68700 KB Output is correct
2 Correct 65 ms 90188 KB Output is correct
3 Correct 114 ms 98640 KB Output is correct
4 Correct 26 ms 82256 KB Output is correct
5 Correct 32 ms 82268 KB Output is correct
6 Correct 11 ms 71704 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 15 ms 74332 KB Output is correct
2 Correct 9 ms 67676 KB Output is correct
3 Correct 64 ms 91220 KB Output is correct
4 Correct 107 ms 97632 KB Output is correct
5 Correct 95 ms 97780 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 93 ms 87188 KB Output is correct
2 Runtime error 1914 ms 262144 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 90 ms 85760 KB Output is correct
2 Correct 566 ms 157656 KB Output is correct
3 Correct 1121 ms 207548 KB Output is correct
4 Correct 1664 ms 254972 KB Output is correct
5 Correct 1553 ms 254600 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 132 ms 91968 KB Output is correct
2 Runtime error 2864 ms 262144 KB Execution killed with signal 9
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 161 ms 91528 KB Output is correct
2 Correct 71 ms 84564 KB Output is correct
3 Correct 1553 ms 203004 KB Output is correct
4 Correct 116 ms 87600 KB Output is correct
5 Runtime error 2827 ms 262144 KB Execution killed with signal 9
6 Halted 0 ms 0 KB -