欢迎访问~原文出处——博客园-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. Python入门系列教程(一)基础

    基础知识 1.变量及类型 2.换行\n 3.输入 password = raw_input("请输入密码:") print '您刚刚输入的密码是:', password 4.格式化 ...

  2. luogu P3191 [HNOI2007]紧急疏散EVACUATE

    传送门 qwq这题好大力 首先可以预处理出每个人到每个门前面那个格子的最早时间,然后答案如果比最小答案大的话也是合法的,所以可以二分最终答案.检查\(mid\)是否合法就考虑每个人要去哪个门才会合法, ...

  3. [JXOI2018]游戏 (线性筛,数论)

    [JXOI2018]游戏 \(solution:\) 这一道题的原版题面实在太负能量了,所以用了修改版题面. 这道题只要仔细读题,我们就可以将题目的一些基本性质分析出来:首先我们定义:对于某一类都可以 ...

  4. 模板·点分治(luogu P3806)

    [模板]洛谷·点分治 1.求树的重心 树的重心:若A点的子树中最大的子树的size[] 最小时,A为该树的中心 步骤: 所需变量:siz[x] 表示 x 的子树大小(含自己),msz[x] 表示 其子 ...

  5. 你真的懂 ajax 吗?

    前言 总括: 本文讲解了ajax的历史,工作原理以及优缺点,对XMLHttpRequest对象进行了详细的讲解,并使用原生js实现了一个ajax对象以方便日常开始使用. damonare的ajax库: ...

  6. 计算正多边形的面积 Gym - 101840G

    http://codeforces.com/gym/101840/attachments 题目大意:输入n,r,k .n代表往外扩张几次,r代表圆的内接圆半径,k代表多边形的边长.问你每次扩张多边形和 ...

  7. mysql 8.0 ~ 安装

    1 环境配置   wget https://dev.mysql.com/get/Downloads/MySQL-8.0/mysql-8.0.13-linux-glibc2.12-x86_64.tar. ...

  8. Android的网络通信机制

    1. Socket接口 不常用 2.HttpURLConnection接口 3. HttpClient接口 http://blog.csdn.net/ccc20134/article/details/ ...

  9. MySQL内连接、外连接、交叉连接

    外连接: 左连接:left join 或 left outer join 以左边的表为基准,如果左表有数据,而右表没有数据,左表的数据正常显示,右表数据显示为空. 创建user表,用于记录用户 use ...

  10. cdh部署

    supermicro安装环境 本次安装基于无因特网的环境,共安装2个节点(一个master节点,一个data及节点),所用系统为centos7.x,所有安装过程均使用root用户.具体的节点信息如下: ...