UVA11754 - Code Feat
Hooray! Agent Bauer has shot the terrorists, blown upthe bad guy base, saved the hostages, exposed the moles in the government,prevented an environmental catastrophe, and found homes for three orphanedkittens, all in the span of 19 consecutive hours. But now, he only has 5 hours remaining todeal with his final challenge: an activated nuclear bomb protected by asecurity code. Can you help him figureout the code and deactivate it? Eventsoccur in real time.
The governmenthackers at CTU (Counter-Terrorist Unit) have learned some things about thecode, but they still haven't quite solved it.They know it's a single, strictly positive, integer. They also know several clues of the form "whendivided by X, the remainder is one of {Y1, Y2, Y3, ...,Yk}".There are multiple solutions to these clues, but the code is likely tobe one of the smallest ones. So they'dlike you to print out the first few solutions, in increasing order.
The world iscounting on you!
Input
Input consistsof several test cases. Each test casestarts with a line containing C, the number of clues (1 <= C <= 9), andS, the number of desired solutions (1 <= S <= 10). The next C lines each start with two integersX (2 <= X) and k (1 <= k <= 100), followed by the k distinct integersY1, Y2, ..., Yk (0 <= Y1,Y2, ..., Yk < X).
You may assumethat the Xs in each test case are pairwise relativelyprime (ie, they have no common factor except 1). Also, the product of the Xs will fit into a32-bit integer.
The last testcase is followed by a line containing two zeros.
Output
For each testcase, output S lines containing the S smallest positive solutions to the clues,in increasing order.
Print a blankline after the output for each test case.
|
Sample Input |
Sample Output |
|
|
3 2 2 1 1 5 2 0 3 3 2 1 2 0 0 |
5 13 |
思路:中国剩余定理+暴力;
首先我们肯定会想到dfs暴力枚举,这种情况只有当所有k的乘积很小的情况下才行,这个时候我们采取dfs+中国剩余定理;当k的乘积很大的情况下,
考虑选择一个K/X最小的条件,然后枚举所有符合这个条件的数n,即 tX+Yi ,t=0,1,2.... 然后依次判断这个n是否符合其它所有条件,因为这个时候x的增量很大。
1 #include <cstdio>
2 #include <iostream>
3 #include <cstring>
4 #include <algorithm>
5 #include <map>
6 #include <vector>
7 #include <set>
8 typedef long long LL;
9 using namespace std;
10 typedef struct node
11 {
12 int x;
13 int y;
14 int bns[105];
15 double b;
16 } ss;
17 set<LL>ask;
18 set<LL>::iterator it;
19 set<int>val[20];
20 ss ans[20];
21 int a[20];
22 void dfs(int x,int y);
23 LL china(int x);
24 pair<LL,LL>ex_gcd(LL n,LL m);
25 void slove__x(int n,int id,int m);
26 LL R;
27 bool cmp(node p,node q)
28 {
29 return p.b < q.b;
30 }
31 int main(void)
32 {
33 int n,m;
34 while(scanf("%d %d",&n,&m)!=EOF)
35 {
36 if(n==0||m==0)break;
37 int i,j;
38 int id = 0;
39 LL um = 1;
40 for(i = 0; i < n; i++)
41 {
42 scanf("%d",&ans[i].x);
43 scanf("%d",&ans[i].y);
44 for(j = 0; j < ans[i].y; j++)
45 {
46 scanf("%d",&ans[i].bns[j]);
47 }
48 sort(ans[i].bns,ans[i].bns+ans[i].y);
49 if(ans[id].x*ans[i].y<ans[i].x*ans[id].y)id=i;
50 um *= ans[i].y;
51 ans[id].b = 1.0*ans[i].y/ans[i].x;
52 }
53 sort(ans,ans+n,cmp);
54 if(um <= 10000)
55 {
56 ask.clear();
57 R = 1;
58 for(i = 0 ; i < n; i++)
59 {
60 R *= ans[i].x;
61 }
62 dfs(0,n);
63 int cn = 0;
64 for(i = 0 ; m!=0; i++)
65 {
66 for(it = ask.begin(); it!=ask.end(); it++)
67 {
68 LL tt = *it + i*R;
69 if(tt > 0)
70 {
71 m--;
72 printf("%lld\n",tt);
73 if(m==0)
74 break;
75 }
76 }
77 }
78 }
79 else
80 {
81 slove__x(n,id,m);
82 }
83 printf("\n");
84 }
85 return 0;
86 }
87 void dfs(int x,int y)
88 {
89 if(x == y)
90 {
91 ask.insert(china(y));
92 return ;
93 }
94 else for(int i = 0; i < ans[x].y; i++)
95 {
96 a[x] = ans[x].bns[i];
97 dfs(x+1,y);
98 }
99 }
100 LL china(int x)
101 {
102 int i,j;
103 LL sum = 0;
104 LL ac = 1;
105 ac = R;
106 for(i = 0; i < x; i++)
107 {
108 LL ak = ac/ans[i].x;
109 pair<LL,LL>cc = ex_gcd(ak,ans[i].x);
110 LL aa = cc.first;
111 aa = (aa%ans[i].x + ans[i].x)%ans[i].x;
112 sum = sum + ((aa*ak%ac)*a[i])%ac;
113 sum %= ac;
114 sum += ac;
115 sum %= ac;
116 }
117 return sum;
118 }
119 pair<LL,LL>ex_gcd(LL n,LL m)
120 {
121 if(m == 0)
122 return make_pair(1,0);
123 else
124 {
125 pair<LL,LL>ac = ex_gcd(m,n%m);
126 return make_pair(ac.second,ac.first-(n/m)*ac.second);
127 }
128 }
129 void slove__x(int n,int id,int m)
130 {
131 int i,j;
132 for(i = 0; i < n; i++)
133 val[i].clear();
134 for(i = 0; i < n; i++)
135 {
136 for(j = 0; j < ans[i].y; j++)
137 {
138 val[i].insert(ans[i].bns[j]);
139 }
140 }
141 for(i = 0; m != 0; i++)
142 {
143 for(j = 0; j < ans[id].y; j++)
144 {
145 LL ak = (LL)i*(LL)ans[id].x + ans[id].bns[j];
146 if(ak > 0)
147 {
148 int flag = 0;
149 for(int c = 0; c < n; c++)
150 {
151 if(c!=id)
152 {
153 if(!val[c].count(ak%ans[c].x))
154 {
155 flag = 1;
156 break;
157 }
158 }
159 }
160 if(!flag)
161 {
162 printf("%lld\n",ak);
163 m--;
164 }
165 if(m==0)break;
166 }
167 }
168 }
169 }
UVA11754 - Code Feat的更多相关文章
- UVA 11754 Code Feat (枚举,中国剩余定理)
转载请注明出处: http://www.cnblogs.com/fraud/ ——by fraud C Code Feat The government hackers at C ...
- UVA 11754 - Code Feat(数论)
UVA 11754 - Code Feat 题目链接 题意:给定一个c个x, y1,y2,y3..yk形式,前s小的答案满足s % x在集合y1, y2, y3 ... yk中 思路:LRJ大白例题, ...
- Uva 11754 Code Feat
题意概述: 有一个正整数$N$满足$C$个条件,每个条件都形如“它除以$X$的余数在集合$\{Y_1, Y_2, ..., Y_k\}$中”,所有条件中的$X$两两互质, 你的任务是找出最小的S个解. ...
- UVA 11754 Code Feat 中国剩余定理+枚举
Code FeatUVA - 11754 题意:给出c个彼此互质的xi,对于每个xi,给出ki个yj,问前s个ans满足ans%xi的结果在yj中有出现过. 一看便是个中国剩余定理,但是同余方程组就有 ...
- UVa 11754 (中国剩余定理 枚举) Code Feat
如果直接枚举的话,枚举量为k1 * k2 *...* kc 根据枚举量的不同,有两种解法. 枚举量不是太大的话,比如不超过1e4,可以枚举每个集合中的余数Yi,然后用中国剩余定理求解.解的个数不够S个 ...
- UVA 11754 Code Feat 中国剩余定理+暴力
lrj白书例题,真好 #include <stdio.h> #include <iostream> #include <vector> #include <m ...
- UVA - 11754 Code Feat (分块+中国剩余定理)
对于一个正整数N,给出C组限制条件,每组限制条件为N%X[i]∈{Y1,Y2,Y3,...,Yk[i]},求满足条件的前S小的N. 这道题很容易想到用中国剩余定理,然后用求第k小集合的方法输出答案.但 ...
- uva 11754 Code Feat (中国剩余定理)
UVA 11754 一道中国剩余定理加上搜索的题目.分两种情况来考虑,当组合总数比较大的时候,就选择枚举的方式,组合总数的时候比较小时就选择搜索然后用中国剩余定理求出得数. 代码如下: #includ ...
- [kuangbin带你飞]专题十四 数论基础
ID Origin Title 111 / 423 Problem A LightOJ 1370 Bi-shoe and Phi-shoe 21 / 74 Problem B ...
随机推荐
- 10.Power of Two-Leetcode
Given an integer, write a function to determine if it is a power of two. class Solution { public: bo ...
- 进程和线程操作系统转载的Mark一下
https://www.cnblogs.com/leisure_chn/p/10393707.html Linux的进程线程及调度 本文为宋宝华<Linux的进程.线程以及调度>学习笔记. ...
- Yarn 生产环境核心配置参数
目录 Yarn 生产环境核心配置参数 ResourceManager NodeManager Container Yarn 生产环境核心配置参数 ResourceManager 配置调度器 yarn. ...
- collection映射
讲了manyToOne和oneToMany,下面来看看get方法.在之前已经说过,如果是映射单对象,直接使用association来映射.而如果关系 是一个集合,则需要使用collection来描述. ...
- Linux基础命令---dig工具
dig dig是一个DNS查询工具,多数管理员会使用dig命令来解决DNS的问题. 此命令的适用范围:RedHat.RHEL.Ubuntu.CentOS.Fedora. 1.语法 di ...
- oracle 锁查询
--v$lock中 id1 在锁模式是 TX 时保存的是 实物id 的前2段SELECT * FROM (SELECT s.SID, TRUNC(id1 / power(2, 16)) rbs, bi ...
- oracle(创建数据库对象)
1 --创建数据库 2 --1.SYSDBA系统权限 3 startup:--启动数据库. 4 shutdown:--关闭数据库. 5 alter database[mount]|[open]|[ba ...
- RHEL 6.5安装系统
转自如下链接: http://www.jb51.net/os/128752.html
- virtualBox 系统移植
把virtualbox已经存在的系统移植到其他机器. 1.把系统如下文件考到一个安装了virtualbox的机器. 2.点击控制-->注册 然后浏览到复制的文件路径. 3.修改uuid 不管是l ...
- SpringBoot 项目不加载 application.properties 配置文件
起因:新安装的idea第一次运行springboot项目报url错误(Failed to configure a DataSource: 'url' attribute is not specifie ...