码迷,mamicode.com
首页 > 其他好文 > 详细

Sicily 7693. Cards

时间:2015-04-15 09:47:29      阅读:233      评论:0      收藏:0      [点我收藏+]

标签:sicily

7693. Cards

Constraints

Time Limit: 15 secs, Memory Limit: 256 MB

Description

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.

技术分享
Figure E-1: Four blue cards and three red cards

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.

Input

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 
b
1 ... 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.

Output

For each dataset, output a line containing an integer that indicates the maximum of the number of the pairs.

Sample Input

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

Sample Output

3
1
0
4
9
18
85

Problem Source

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 7693. Cards

标签:sicily

原文地址:http://blog.csdn.net/u012925008/article/details/45048213

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!