Submission #64382848


Source Code Expand

Copy
#include <stdio.h>
#include <inttypes.h>
/* {1,2,3} -> ... -> {3,2,1} */
int next_permutation(int arr[],int n) {
int target;
int i;
int temp;
for (i = n - 2; i >= 0; i--) {
if (arr[i] < arr[i + 1]) break;
}
if (i < 0) return 0;
target = i;
for (i = 0; target + i + 1 < n - i - 1; i++) {
temp = arr[target + 1 + i];
arr[target + 1 + i] = arr[n - 1 - i];
arr[n - i - 1] = temp;
}
for (i = target + 1; i < n; i++) {
 
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
#include <stdio.h>
#include <inttypes.h>

/* {1,2,3} -> ... -> {3,2,1} */
int next_permutation(int arr[],int n) {
	int target;
	int i;
	int temp;
	for (i = n - 2; i >= 0; i--) {
		if (arr[i] < arr[i + 1]) break;
	}
	if (i < 0) return 0;
	target = i;

	for (i = 0; target + i + 1 < n - i - 1; i++) {
		temp = arr[target + 1 + i];
		arr[target + 1 + i] = arr[n - 1 - i];
		arr[n - i - 1] = temp;
	}

	for (i = target + 1; i < n; i++) {
		if (arr[i] > arr[target]) break;
	}
	temp = arr[i];
	arr[i] = arr[target];
	arr[target] = temp;
	return 1;
}

#define NONE (UINT64_C(1) << 63)

uint64_t w[16][16];

int main(void) {
	int N, M;
	int i, j;
	int order[16];
	uint64_t ans = NONE;
	if (scanf("%d%d", &N, &M) != 2) return 1;
	for (i = 1; i <= N; i++) {
		for (j = 1; j <= N; j++) {
			w[i][j] = NONE;
		}
		order[i - 1] = i;
	}
	for (i = 0; i < M; i++) {
		int u, v;
		uint64_t w_;
		if (scanf("%d%d%" SCNu64, &u, &v, &w_) != 3) return 1;
		w[u][v] = w[v][u] = w_;
	}
	do {
		uint64_t candidate = 0;
		for (i = 1; i < N; i++) {
			uint64_t label = w[order[i - 1]][order[i]];
			if (label & NONE) {
				candidate = NONE;
				break;
			}
			candidate ^= label;
			if (order[i] == N) break;
		}
		if (candidate < ans) ans = candidate;
	} while (next_permutation(order + 1, N - 1));
	printf("%" PRIu64 "\n", ans);
	return 0;
}

Submission Info

Submission Time
Task D - Minimum XOR Path
User mikecat
Language C (gcc 12.2.0)
Score 400
Code Size 1386 Byte
Status AC
Exec Time 3 ms
Memory 1756 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 400 / 400
Status
AC × 3
AC × 32
Set Name Test Cases
Sample 00_sample_00.txt, 00_sample_01.txt, 00_sample_02.txt
All 00_sample_00.txt, 00_sample_01.txt, 00_sample_02.txt, 01_test_00.txt, 01_test_01.txt, 01_test_02.txt, 01_test_03.txt, 01_test_04.txt, 01_test_05.txt, 01_test_06.txt, 01_test_07.txt, 01_test_08.txt, 01_test_09.txt, 01_test_10.txt, 01_test_11.txt, 01_test_12.txt, 01_test_13.txt, 01_test_14.txt, 01_test_15.txt, 01_test_16.txt, 01_test_17.txt, 01_test_18.txt, 01_test_19.txt, 01_test_20.txt, 01_test_21.txt, 01_test_22.txt, 01_test_23.txt, 01_test_24.txt, 01_test_25.txt, 01_test_26.txt, 01_test_27.txt, 01_test_28.txt
Case Name Status Exec Time Memory
00_sample_00.txt AC 1 ms 1728 KB
00_sample_01.txt AC 1 ms 1716 KB
00_sample_02.txt AC 1 ms 1612 KB
01_test_00.txt AC 1 ms 1632 KB
01_test_01.txt AC 2 ms 1752 KB
01_test_02.txt AC 1 ms 1756 KB
01_test_03.txt AC 2 ms 1580 KB
01_test_04.txt AC 1 ms 1724 KB
01_test_05.txt AC 2 ms 1728 KB
01_test_06.txt AC 1 ms 1636 KB
01_test_07.txt AC 2 ms 1716 KB
01_test_08.txt AC 1 ms 1652 KB
01_test_09.txt AC 3 ms 1580 KB
01_test_10.txt AC 1 ms 1720 KB
01_test_11.txt AC 3 ms 1648 KB
01_test_12.txt AC 1 ms 1640 KB
01_test_13.txt AC 3 ms 1616 KB
01_test_14.txt AC 1 ms 1752 KB
01_test_15.txt AC 3 ms 1632 KB
01_test_16.txt AC 1 ms 1600 KB
01_test_17.txt AC 3 ms 1624 KB
01_test_18.txt AC 1 ms 1724 KB
01_test_19.txt AC 3 ms 1720 KB
01_test_20.txt AC 3 ms 1620 KB
01_test_21.txt AC 3 ms 1716 KB
01_test_22.txt AC 3 ms 1636 KB
01_test_23.txt AC 3 ms 1724 KB
01_test_24.txt AC 2 ms 1740 KB
01_test_25.txt AC 1 ms 1624 KB
01_test_26.txt AC 2 ms 1616 KB
01_test_27.txt AC 1 ms 1616 KB
01_test_28.txt AC 1 ms 1708 KB


2025-03-31 (Mon)
08:30:13 +09:00