UVA 11754 (暴力+中国剩余定理)
题目链接: http://www.bnuoj.com/v3/problem_show.php?pid=20172
题目大意:有C个模方程,每个方程可能有k余数,求最小的S个解。
解题思路:
看见模方程就想到中国剩余定理,然后看下确定的方程情况。
由乘法原理,共有II ki 种情况,即求解II ki 次。k比较大时基本完蛋。
其实解模方程还有一种暴力方法,就是选定一个模方程,令t=0,1...., n=t*LCM+余数(n一定要大于0)
通过t不断增大这种迭代方式从小到大创造一些可能解n,然后去测试其它方程,看余数对不对。
如果余数全对,那么就找到了一个解。否则就砍掉。
因为测试是很快的,大部分数据一开始就被砍了,所以k比较大时速度非常快。
毕竟上面是看RP的暴力,所以设定一个分界(10000),如果II ki <10000 ,那么还是通过中国剩余定理来求解,复杂度O(n)。
方法就是DFS枚举出C个余数情况,然后求解。
由于求出的全是最小整数解,S比较大时,剩余定理的解可能不足,这时候从小到大每个值加M的倍数凑出更大的解。
#include "cstdio"
#include "set"
#include "vector"
#include "algorithm"
using namespace std;
#define LL long long
#define LIMIT 10000
int C,S,s;
LL m[],k[],y[][],a[],M;
set<LL> value[];
vector<LL> ans;
void solve_violence(int bc)
{
for(int i=;i<=C;i++)
{
value[i].clear();
if(i!=bc) for(int j=;j<=k[i];j++) value[i].insert(y[i][j]);
}
for(int t=;S!=;t++)
{
for(int i=;i<=k[bc];i++)
{
LL n=t*m[bc]+y[bc][i];
if(!n) continue;
bool ok=true;
for(int j=;j<=C;j++)
{
if(j==bc) continue;
if(!value[j].count(n%m[j])) {ok=false;break;}
}
if(ok) {printf("%lld\n",n);if(--S==) return;}
}
}
}
LL ex_gcd(LL a,LL b,LL &x,LL &y)
{
if(a==&&b==) return -;
if(b==) {x=;y=;return a;}
LL d=ex_gcd(b,a%b,y,x);
y-=a/b*x;
return d;
}
LL solve_china()
{
LL res=;M=;
for(int i=;i<=C;i++) M*=m[i];
for(int i=;i<=C;i++)
{
LL w=M/m[i],x,y;
ex_gcd(m[i],w,x,y);
y=(y*w%M+M)%M;
res=(res+y*a[i])%M;
}
return res;
}
void dfs(int dep)
{
if(dep>C)
{
ans.push_back(solve_china());
return;
}
for(int i=;i<=k[dep];i++)
{
a[dep]=y[dep][i];
dfs(dep+);
}
}
int main()
{
//freopen("in.txt","r",stdin);
while(scanf("%d%d",&C,&S)&&C)
{
int bestc=;ans.clear();s=S;M=;
LL tot=;
for(int i=;i<=C;i++)
{
scanf("%lld%lld",&m[i],&k[i]);
tot*=k[i];
if(k[i]*m[bestc]<k[bestc]*m[i]) bestc=i;
for(int j=;j<=k[i];j++) scanf("%lld",&y[i][j]);
sort(y[i]+,y[i]++k[i]);
}
if(tot<LIMIT)
{
dfs();
sort(ans.begin(),ans.end());
for(int t=;S!=;t++)
for(int i=;i<ans.size();i++)
{
LL n=t*M+ans[i];
if(n>)
{
printf("%lld\n",n);
if(--S==) break;
}
}
}
else solve_violence(bestc);
printf("\n");
}
}
| neopenx | 445520 | 20172 | Accepted | GNU C++ | 26 ms | 2223 B | 2015-02-06 23:10:03 |
UVA 11754 (暴力+中国剩余定理)的更多相关文章
- Uva 11754(枚举+中国剩余定理)
#include<iostream> #include<cstdio> #include<cmath> #include<cstring> #inclu ...
- uva 11754 Code Feat (中国剩余定理)
UVA 11754 一道中国剩余定理加上搜索的题目.分两种情况来考虑,当组合总数比较大的时候,就选择枚举的方式,组合总数的时候比较小时就选择搜索然后用中国剩余定理求出得数. 代码如下: #includ ...
- 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 (枚举,中国剩余定理)
转载请注明出处: http://www.cnblogs.com/fraud/ ——by fraud C Code Feat The government hackers at C ...
- uva11754 中国剩余定理+暴力搜索
是当y的组合数较小时,暴力枚举所有组合,然后用中国剩余定理求每种组合的解,对解进行排序即可 注意初始解可能是负数,所以如果凑不够S个,就对所有解加上M,2M.... 当y的组合数较大时,选择一个k/x ...
- UVA 11754 - Code Feat(数论)
UVA 11754 - Code Feat 题目链接 题意:给定一个c个x, y1,y2,y3..yk形式,前s小的答案满足s % x在集合y1, y2, y3 ... yk中 思路:LRJ大白例题, ...
- poj1006 ( hdu1370 ):中国剩余定理裸题
裸题,没什么好说的 第一个中国剩余定理 写暴力都过了..可见这题有多水 代码: #include<iostream> #include<stdio.h> #include< ...
- [bzoj2142]礼物(扩展lucas定理+中国剩余定理)
题意:n件礼物,送给m个人,每人的礼物数确定,求方案数. 解题关键:由于模数不是质数,所以由唯一分解定理, $\bmod = p_1^{{k_1}}p_2^{{k_2}}......p_s^{{k_ ...
随机推荐
- 使用HttpWebRequest发送自定义POST请求
平时用浏览器看网页的时候,点击一下submit按钮的时候其实就是给服务器发送了一个POST请求.但是如何在自己的C#程序里面实现类似的功能呢?本文给出了一个简单的范例,可以实现类似的和web serv ...
- Java集合源码学习(一)集合框架概览
>>集合框架 Java集合框架包含了大部分Java开发中用到的数据结构,主要包括List列表.Set集合.Map映射.迭代器(Iterator.Enumeration).工具类(Array ...
- Asp.net窄屏页面 手机端新闻列表
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="SearchNotice.a ...
- 无废话Android之listview入门,自定义的数据适配器、采用layoutInflater打气筒创建一个view对象、常用数据适配器ArrayAdapter、SimpleAdapter、使用ContentProvider(内容提供者)共享数据、短信的备份、插入一条记录到系统短信应用(3)
1.listview入门,自定义的数据适配器 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/and ...
- Linux 下 Console / 控制台 复制粘贴快捷键
Linux下复制粘贴快捷键 1. 在终端下: 复制命令:Ctrl + Shift + C 组合键. 粘贴命令:Ctrl + Shift + V 组合键. 2. 在控制台下: 复制命令:Ctrl + ...
- 图结构练习——最短路径(dijkstra算法(迪杰斯拉特))
图结构练习——最短路径 Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 给定一个带权无向图,求节点1到节点n的最短路径. ...
- C与C++之间相互调用
1.导出C函数以用于C或C++的项目 如果使用C语言编写的DLL,希望从中导出函数给C或C++的模块访问,则应使用 __cplusplus 预处理器宏确定正在编译的语言.如果是从C++语言模块使用,则 ...
- POJ2065 SETI(高斯消元 同模方程)
(a1 * 1^0 + a2 * 1^1 + ... an * 1^n - 1) % P = f1 .... (a1 * n^0 + a2 * n^1 + ... an - 1 * ...
- 攻城狮在路上(壹) Hibernate(六)--- 通过Hibernate操纵对象(上)
一.Hibernate缓存简介: Session接口是Hibernate向应用程序提供的操纵数据接口的最主要接口,它提供了基本的保存.更新.删除和加载Java对象的方法. Session具有一个缓存, ...
- Oracle性能优化之SQL语句
1.SQL语句执行过程 1.1 SQL语句的执行步骤 1)语法分析,分析语句的语法是否符合规范,衡量语句中各表达式的意义. 2)语义分析,检查语句中涉及的所有数据库对象是否存在,且用户有相应的权限. ...