欢迎访问~原文出处——博客园-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 解方程 其他的更多相关文章

  1. 【NOIP2014提高组】解方程

    https://www.luogu.org/problem/show?pid=2312 对于30%的数据,n<=2,暴力带入试解.对于50%的数据,ai很大,结合高精乘法和霍纳算法暴力代入试解. ...

  2. 【NOIP】提高组2014 解方程

    [题意]已知n次方程(n<=100)及其所有系数(|ai|<=10^10000),求[1,m]中整数解的个数(m<=10^6). [算法]数论 [题解]如果f(x)=0,则有f(x) ...

  3. [NOIP2014] 提高组 洛谷P2038 无线网络发射器选址

    题目描述 随着智能手机的日益普及,人们对无线网的需求日益增大.某城市决定对城市内的公共场所覆盖无线网. 假设该城市的布局为由严格平行的129 条东西向街道和129 条南北向街道所形成的网格状,并且相邻 ...

  4. 刷题总结——飞扬的小鸟(NOIP2014提高组)

    题目: 题目背景 NOIP2014 提高组 Day1 试题. 题目描述 Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面 ...

  5. 垃圾陷阱 && [NOIP2014 提高组] 飞扬的小鸟

    #include<bits/stdc++.h> using namespace std; int d,n,dp[1010]; struct node{int t,f,h;} a[1010] ...

  6. NOIP2014提高组 酱油记

    NOIP考到哪里我就写到哪里好了. 2014/10/12 初赛 下午两点半开始考,我两点就到了.然后看到了QYL,NYZ,CZR等大神,先Orz了再说. 考试开始前,发现考场竟然没几个我认识的,不是按 ...

  7. 刷题总结——mayan游戏(NOIP2011提高组day2T3)

    题目: 题目背景 NOIP2011提高组 DAY1 试题. 题目描述 Mayan puzzle 是最近流行起来的一个游戏.游戏界面是一个 7 行 5 列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即 ...

  8. cogs 2109. [NOIP 2015] 运输计划 提高组Day2T3 树链剖分求LCA 二分答案 差分

    2109. [NOIP 2015] 运输计划 ★★★☆   输入文件:transport.in   输出文件:transport.out   简单对比时间限制:3 s   内存限制:256 MB [题 ...

  9. noip2014 提高组

    T1 生活大爆炸版 石头剪刀布 题目传送门 就是道模拟题咯 #include<algorithm> #include<cstdio> #include<cstring&g ...

随机推荐

  1. SQL语句——重复记录

    1.查找重复记录: (按id查找) select * from user_info where id in ( select id from user_info group by id ) 即:sel ...

  2. java操作Hbase

    public class Test { public Connection connection; // 用HBaseconfiguration初始化配置信息是会自动加载当前应用的classpath下 ...

  3. new和delete

    和 sizeof 类似,sizeof不是函数,它是一个操作符,它在编译期就完成了计算,在函数运行期间它已经是一个常数值了. int a; sizeof(int) = 4; sizeof(a) = 4; ...

  4. comfirm和prompt的区别

    comfirm和prompt的区别. <html> <title>测试页面</title> <head> </head> <body& ...

  5. python技巧 列表推导

    val = [expression for value in collection if condition] 等价于 val = []for value in collection:    if c ...

  6. tr 设置margin、padding无效

    tr.td设置margin 无效 tr 设置padding无效.td设置padding有效

  7. 编写灵活、稳定、高质量的 css代码的规范

    语法 用两个空格来代替制表符(tab) -- 这是唯一能保证在所有环境下获得一致展现的方法. 为选择器分组时,将单独的选择器单独放在一行. 为了代码的易读性,在每个声明块的左花括号前添加一个空格. 声 ...

  8. SSM框架中将时间写入数据库的格式定义

    //声明Date类接收的数据格式 @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") private Date addtime;

  9. EXT3.3.1在IE9 IE10click事件 失效怎么解决

    各位Ext君有福了. var treePanel = new Ext.tree.TreePanel({ id:'treePanel_'+(menuIndex++),//让菜单id可控 title: t ...

  10. nodejs async series 小白向

    async.series({  flag1:function(done){ //flag1 是一个流程标识,用户自定义      //逻辑处理      done(null,"返回结果&qu ...