标签:sicily
Time Limit: 15 secs, Memory Limit: 256 MB
There are many blue cards and red cards on the table. For each card, an integer number greater than 1 is printed on its face. The same number may be printed on several cards.
A blue card and a red card can be paired when both of the numbers printed on them have a common divisor greater than 1. There may be more than one red card that can be paired with one blue card. Also, there may be more than one blue card that can be paired with one red card. When a blue card and a red card are chosen and paired, these two cards are removed from the whole cards on the table.
For example, in Figure E-1, there are four blue cards and three red cards. Numbers 2, 6, 6 and 15 are printed on the faces of the four blue cards, and 2, 3 and 35 are printed on those of the three red cards. Here, you can make pairs of blue cards and red cards as follows. First, the blue card with number 2 on it and the red card with 2 are paired and removed. Second, one of the two blue cards with 6 and the red card with 3 are paired and removed. Finally, the blue card with 15 and the red card with 35 are paired and removed. Thus the number of removed pairs is three.
Note that the total number of the pairs depends on the way of choosing cards to be paired. The blue card with 15 and the red card with 3 might be paired and removed at the beginning. In this case, there are only one more pair that can be removed and the total number of the removed pairs is two.
Your job is to find the largest number of pairs that can be removed from the given set of cards on the table.
The input is a sequence of datasets. The number of the datasets is less than or equal to 100. Each dataset is formatted as follows.
m n
b1 ... bk ... bm
r1 ... rk ... rn
The integers m and n are the number of blue cards and that of red cards, respectively. You may assume 1 ≤ m ≤ 500 and 1≤ n ≤ 500. bk (1 ≤ k ≤ m) and rk(1 ≤ k ≤ n) are numbers printed on the blue cards and the red cards respectively, that are integers greater than or equal to 2 and less than 10000000 (=107). The input integers are separated by a space or a newline. Each of bm and rn is followed by a newline. There are no other characters in the dataset.
The end of the input is indicated by a line containing two zeros separated by a space.
For each dataset, output a line containing an integer that indicates the maximum of the number of the pairs.
4 3 2 6 6 15 2 3 5 2 3 4 9 8 16 32 4 2 4 9 11 13 5 7 5 5 2 3 5 1001 1001 7 11 13 30 30 10 10 2 3 5 7 9 11 13 15 17 29 4 6 10 14 18 22 26 30 34 38 20 20 195 144 903 63 137 513 44 626 75 473 876 421 568 519 755 840 374 368 570 872 363 650 155 265 64 26 426 391 15 421 373 984 564 54 823 477 565 866 879 638 100 100 195 144 903 63 137 513 44 626 75 473 876 421 568 519 755 840 374 368 570 872 363 650 155 265 64 26 426 391 15 421 373 984 564 54 823 477 565 866 879 638 117 755 835 683 52 369 302 424 513 870 75 874 299 228 140 361 30 342 750 819 761 123 804 325 952 405 578 517 49 457 932 941 988 767 624 41 912 702 241 426 351 92 300 648 318 216 785 347 556 535 166 318 434 746 419 386 928 996 680 975 231 390 916 220 933 319 37 846 797 54 272 924 145 348 350 239 563 135 362 119 446 305 213 879 51 631 43 755 405 499 509 412 887 203 408 821 298 443 445 96 274 715 796 417 839 147 654 402 280 17 298 725 98 287 382 923 694 201 679 99 699 188 288 364 389 694 185 464 138 406 558 188 897 354 603 737 277 35 139 556 826 213 59 922 499 217 846 193 416 525 69 115 489 355 256 654 49 439 118 961 0 0
3 1 0 4 9 18 85
2013年每周一赛第二场/Japan Domestic Contest 2009
贪心。
#include <stdio.h> int m, n; bool isConnect[505][505]; int b[505], r[505], bConnectNum[505], rConnectNum[505]; inline int gcd(int a, int b) { int temp; while (b) { temp = a % b; a = b; b = temp; } return a; } int main() { char c[10000]; int sum, k; while (1) { scanf("%d%d", &m, &n); if (m == 0 && n == 0) break; gets(c); k = 0; while (k < m) { gets(c); sum = 0; for (int i = 0; c[i] != '\0'; i++) { if (c[i] == ' ') { b[k++] = sum; sum = 0; } else sum = sum * 10 + c[i] - '0'; } b[k++] = sum; } k = 0; while (k < n) { gets(c); sum = 0; for (int i = 0; c[i] != '\0'; i++) { if (c[i] == ' ') { r[k++] = sum; sum = 0; } else sum = sum * 10 + c[i] - '0'; } r[k++] = sum; } for (int i = 0; i < m; i++) { int cn = b[i]; int num = 0; for (int j = 0; j < n; j++) { if (gcd(cn, r[j]) != 1) { isConnect[i][j] = true; num++; } else isConnect[i][j] = false; } bConnectNum[i] = num; } for (int j = 0; j < n; j++) { int num = 0; for (int i = 0; i < m; i++) { if (isConnect[i][j]) num++; } rConnectNum[j] = num; } int ans = 0; while (1) { int bpos = -1, rpos, min = n + 1; for (int i = 0; i < m; i++) { if (bConnectNum[i] && bConnectNum[i] < min) { bpos = i; min = bConnectNum[i]; } } if (bpos == -1) break; ans++; min = m + 1; for (int j = 0; j < n; j++) { if (isConnect[bpos][j] && rConnectNum[j] < min) { rpos = j; min = rConnectNum[j]; } } isConnect[bpos][rpos] = false; bConnectNum[bpos] = 0; rConnectNum[rpos] = 0; for (int i = 0; i < m; i++) { if (isConnect[i][rpos]) { isConnect[i][rpos] = false; bConnectNum[i]--; } } for (int j = 0; j < n; j++) { if (isConnect[bpos][j]) { isConnect[bpos][j] = false; rConnectNum[j]--; } } } printf("%d\n", ans); } return 0; }
标签:sicily
原文地址:http://blog.csdn.net/u012925008/article/details/45048213