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的更多相关文章

  1. UVA 11754 Code Feat (枚举,中国剩余定理)

    转载请注明出处: http://www.cnblogs.com/fraud/          ——by fraud C Code Feat   The government hackers at C ...

  2. UVA 11754 - Code Feat(数论)

    UVA 11754 - Code Feat 题目链接 题意:给定一个c个x, y1,y2,y3..yk形式,前s小的答案满足s % x在集合y1, y2, y3 ... yk中 思路:LRJ大白例题, ...

  3. Uva 11754 Code Feat

    题意概述: 有一个正整数$N$满足$C$个条件,每个条件都形如“它除以$X$的余数在集合$\{Y_1, Y_2, ..., Y_k\}$中”,所有条件中的$X$两两互质, 你的任务是找出最小的S个解. ...

  4. UVA 11754 Code Feat 中国剩余定理+枚举

    Code FeatUVA - 11754 题意:给出c个彼此互质的xi,对于每个xi,给出ki个yj,问前s个ans满足ans%xi的结果在yj中有出现过. 一看便是个中国剩余定理,但是同余方程组就有 ...

  5. UVa 11754 (中国剩余定理 枚举) Code Feat

    如果直接枚举的话,枚举量为k1 * k2 *...* kc 根据枚举量的不同,有两种解法. 枚举量不是太大的话,比如不超过1e4,可以枚举每个集合中的余数Yi,然后用中国剩余定理求解.解的个数不够S个 ...

  6. UVA 11754 Code Feat 中国剩余定理+暴力

    lrj白书例题,真好 #include <stdio.h> #include <iostream> #include <vector> #include <m ...

  7. UVA - 11754 Code Feat (分块+中国剩余定理)

    对于一个正整数N,给出C组限制条件,每组限制条件为N%X[i]∈{Y1,Y2,Y3,...,Yk[i]},求满足条件的前S小的N. 这道题很容易想到用中国剩余定理,然后用求第k小集合的方法输出答案.但 ...

  8. uva 11754 Code Feat (中国剩余定理)

    UVA 11754 一道中国剩余定理加上搜索的题目.分两种情况来考虑,当组合总数比较大的时候,就选择枚举的方式,组合总数的时候比较小时就选择搜索然后用中国剩余定理求出得数. 代码如下: #includ ...

  9. [kuangbin带你飞]专题十四 数论基础

            ID Origin Title   111 / 423 Problem A LightOJ 1370 Bi-shoe and Phi-shoe   21 / 74 Problem B ...

随机推荐

  1. Android editttext只能输入不能删除(选中后被软键盘遮住)

    感谢https://www.dutycode.com/post-20.html: 解决方法:在布局外外嵌一层scrollview.

  2. 巩固javaweb第十四天

    巩固内容: 单行文本框: 单行文本框的基本语法格式如下: < input type="text"  name="输入信息的字"  value=" ...

  3. 关于java中的安全管理器

    最近再查看java的源码的时候看见了这一类代码 final SecurityManager sm = System.getSecurityManager(); 想要了解这个是为了做什么,查看资料之后发 ...

  4. gen already exists but is not a source folder. Convert to a source folder or rename it 的解决办法

    1. Right click on the project and go to "Properties" //鼠标右键点击项目,然后选中Properties   2. Select ...

  5. linux如何安装缺失依赖

    这里要提到一个网站https://pkgs.org/,他是linux系统的一个相关网站,里面都是相关内容 Warning: RPMDB altered outside of yum. ** Found ...

  6. oralce 存储过程传入 record 类型的参数?

    先定义一个 package , package中含有一个 record 类型的变量 create or replace package pkg_record is type emp_record is ...

  7. redis入门到精通系列(七):redis高级数据类型详解(BitMaps,HyperLogLog,GEO)

    高级数据类型和五种基本数据类型不同,并非新的数据结构.高级数据类型往往是用来解决一些业务场景. (一)BitMaps (1.1) BitMaps概述 在应用场景中,有一些数据只有两个属性,比如是否是学 ...

  8. this指针的用法和基本分析

    当在不同的对象中采用this指针,就已经是在给它赋值了.对象各自的this指针指向各自对象的首地址,所以不同对象的this指针一定指向不同的内存地址. this 指针是由系统自动提供的指向对象的特殊指 ...

  9. 3.Vue.js-目录结构

    Vue.js 目录结构 上一章节中我们使用了 npm 安装项目,我们在 IDE(Eclipse.Atom等) 中打开该目录,结构如下所示: 目录解析 目录/文件 说明 build 项目构建(webpa ...

  10. HCL华三模拟器静态路由实验

    (copy自我的其他博客网站) 拓扑如下: 实验目的:通过给A.B.C三台路由器配置静态路由,使PC1可以ping通PC2. 实验环境:Windows10 (21H1),HCL(V3.0.1) 实验步 ...