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++) {
#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 |
|
|
| 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 |