Vijos1910 NOIP2014提高组 Day2T3 解方程 其他
欢迎访问~原文出处——博客园-zhouzhendong
去博客园看该题解
题目传送门 - Vijos1910
题意概括
已知多项式方程:
a0+a1x+a2x2+...+anxn=0
求这个方程在[1, m]内的整数解(n 和 m 均为正整数)。
对于 100%的数据,0 < n ≤ 100, |ai| ≤ 1010000 ,an ≠ 0,m ≤ 1000000。
题解
我们假如在模意义下解这个方程,就可以省去高精度的复杂度,时间复杂度就没问题了。
但是这样做会导致数据失真。
有一定概率出错。
所以我们考虑多取几个大模数,最好是质数。
然后一起弄一遍,然后就可以过了。
注意,对于一个素数X,我们需要枚举判断的是0~X-1这个区间。
对于X~m这段,由于是在模意义下的,所以对于a+kx这个数,就等价于a。
然后随便找几个大模数,排除法就可以了。
代码
#include <cstring>
#include <algorithm>
#include <cstdlib>
#include <cstdio>
#include <cmath>
using namespace std;
const int N=105,M=1000005,L=10000+5;
int prime[5]={15737,19127,13553,23333,6667};
int n,m,a[N][5];
bool alive[M],now[M];
char number[L];
int main(){
scanf("%d%d",&n,&m);
memset(alive,true,sizeof alive);
for (int x=0;x<=n;x++){
scanf("%s",&number);
int len=strlen(number);
for (int i=0;i<5;i++){
a[x][i]=0;
for (int j=number[0]=='-';j<len;j++)
a[x][i]=(a[x][i]*10+number[j]-'0')%prime[i];
if (number[0]=='-')
a[x][i]=(prime[i]-a[x][i])%prime[i];
}
}
for (int i=0;i<5;i++){
memset(now,true,sizeof now);
for (int v=0;v<prime[i];v++){
int tot=a[0][i],Pow=v;
for (int j=1;j<=n;j++)
tot=(tot+a[j][i]*Pow)%prime[i],Pow=Pow*v%prime[i];
if (tot!=0)
now[v]=0;
}
for (int v=0;v<prime[i];v++)
if (!now[v])
for (int j=v;j<=m;j+=prime[i])
alive[j]=0;
}
int tot=0;
for (int i=1;i<=m;i++)
if (alive[i])
tot++;
printf("%d\n",tot);
for (int i=1;i<=m;i++)
if (alive[i])
printf("%d\n",i);
return 0;
}
Vijos1910 NOIP2014提高组 Day2T3 解方程 其他的更多相关文章
- 【NOIP2014提高组】解方程
		https://www.luogu.org/problem/show?pid=2312 对于30%的数据,n<=2,暴力带入试解.对于50%的数据,ai很大,结合高精乘法和霍纳算法暴力代入试解. ... 
- 【NOIP】提高组2014 解方程
		[题意]已知n次方程(n<=100)及其所有系数(|ai|<=10^10000),求[1,m]中整数解的个数(m<=10^6). [算法]数论 [题解]如果f(x)=0,则有f(x) ... 
- [NOIP2014] 提高组 洛谷P2038 无线网络发射器选址
		题目描述 随着智能手机的日益普及,人们对无线网的需求日益增大.某城市决定对城市内的公共场所覆盖无线网. 假设该城市的布局为由严格平行的129 条东西向街道和129 条南北向街道所形成的网格状,并且相邻 ... 
- 刷题总结——飞扬的小鸟(NOIP2014提高组)
		题目: 题目背景 NOIP2014 提高组 Day1 试题. 题目描述 Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面 ... 
- 垃圾陷阱 &&  [NOIP2014 提高组] 飞扬的小鸟
		#include<bits/stdc++.h> using namespace std; int d,n,dp[1010]; struct node{int t,f,h;} a[1010] ... 
- NOIP2014提高组 酱油记
		NOIP考到哪里我就写到哪里好了. 2014/10/12 初赛 下午两点半开始考,我两点就到了.然后看到了QYL,NYZ,CZR等大神,先Orz了再说. 考试开始前,发现考场竟然没几个我认识的,不是按 ... 
- 刷题总结——mayan游戏(NOIP2011提高组day2T3)
		题目: 题目背景 NOIP2011提高组 DAY1 试题. 题目描述 Mayan puzzle 是最近流行起来的一个游戏.游戏界面是一个 7 行 5 列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即 ... 
- cogs 2109. [NOIP 2015] 运输计划 提高组Day2T3 树链剖分求LCA 二分答案 差分
		2109. [NOIP 2015] 运输计划 ★★★☆ 输入文件:transport.in 输出文件:transport.out 简单对比时间限制:3 s 内存限制:256 MB [题 ... 
- noip2014 提高组
		T1 生活大爆炸版 石头剪刀布 题目传送门 就是道模拟题咯 #include<algorithm> #include<cstdio> #include<cstring&g ... 
随机推荐
- SQL语句——重复记录
			1.查找重复记录: (按id查找) select * from user_info where id in ( select id from user_info group by id ) 即:sel ... 
- java操作Hbase
			public class Test { public Connection connection; // 用HBaseconfiguration初始化配置信息是会自动加载当前应用的classpath下 ... 
- new和delete
			和 sizeof 类似,sizeof不是函数,它是一个操作符,它在编译期就完成了计算,在函数运行期间它已经是一个常数值了. int a; sizeof(int) = 4; sizeof(a) = 4; ... 
- comfirm和prompt的区别
			comfirm和prompt的区别. <html> <title>测试页面</title> <head> </head> <body& ... 
- python技巧 列表推导
			val = [expression for value in collection if condition] 等价于 val = []for value in collection: if c ... 
- tr 设置margin、padding无效
			tr.td设置margin 无效 tr 设置padding无效.td设置padding有效 
- 编写灵活、稳定、高质量的 css代码的规范
			语法 用两个空格来代替制表符(tab) -- 这是唯一能保证在所有环境下获得一致展现的方法. 为选择器分组时,将单独的选择器单独放在一行. 为了代码的易读性,在每个声明块的左花括号前添加一个空格. 声 ... 
- SSM框架中将时间写入数据库的格式定义
			//声明Date类接收的数据格式 @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") private Date addtime; 
- EXT3.3.1在IE9 IE10click事件 失效怎么解决
			各位Ext君有福了. var treePanel = new Ext.tree.TreePanel({ id:'treePanel_'+(menuIndex++),//让菜单id可控 title: t ... 
- nodejs async series 小白向
			async.series({ flag1:function(done){ //flag1 是一个流程标识,用户自定义 //逻辑处理 done(null,"返回结果&qu ... 
