背景

B酱为NOIP 2014出了一道有趣的题目, 可是在NOIP现场, B酱发现数据规模给错了, 他很伤心, 哭得很可怜.....

为了安慰可怜的B酱, vijos刻意挂出来了真实的题目!

描述

已知多项式方程:

$$a_0+a_1x+a_2x^2+...+a_nx^n=0$$

求这个方程在[1, m]内的整数解(n 和 m 均为正整数)。

输入格式

输入共 n+2 行。

第一行包含 2 个整数 n、m,每两个整数之间用一个空格隔开。

接下来的 n+1 行每行包含一个整数,依次为$a_0,a_1,a_2,...a_n$。

输出格式

第一行输出方程在[1, m]内的整数解的个数。

接下来每行一个整数,按照从小到大的顺序依次输出方程在[1, m]内的一个整数解。

限制

对于20%的数据,$0<n\leq 100$,$|a_i|<=10^{100}$,$a_n \neq 0$,$m\leq 100$;
对于40%的数据,$0<n\leq 100$,$|a_i|<=10^{10000}$,$a_n \neq 0$,$m\leq 10000$;
对于70%的数据,$0<n\leq 100$,$|a_i|<=10^{10000}$,$a_n \neq 0$,$m\leq 1000000=10^6$;
对于100%的数据,$0<n\leq 100$,$|a_i|<=10^{10000}$,$a_n \neq 0$,$m\leq 100000000=10^8$。

[实际上来说就算m <= 10^10也是可以做的, 不过我把时间限制设定为0.5秒,感觉也差不多了。THU某人: O(m)的算法过不去了, 呜呜呜....]

  刚把$noip$的欠账:解方程给补上,又发现了vijos上还有一道加强版。这道题主要就是把$m$的范围加强到了$10^8$,卡掉了$O(m)$的算法。题解戳这里

  不过这道题我把解方程$O(m)$的算法稍微优化了一下,然后就这么过去了……

  原题$O(m)$的算法主要就是自己设一个模数$p$,先把区间$[0,p)$中的解给算出来,然后方程在$x$处的取值就是方程在$x \bmod p$处的取值,于是可以在$O(pn)$的处理后,用$O(m)$的复杂度得到方程在$[1,m]$中的取值。然而这样其实是有非常多的冗余状态的,因为真正对我们有用的位置只是值为$0$的位置。于是我们可以只处理这些位置,分别存到数组中,最后判断一下某个值是否在每个模数下都出现即可。加了这一点优化后即可获得$AC$。

  还有我的这份代码在BZOJ上A不了,需要换一组模数……果然我还是血统不行……

  下面贴代码:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#define File(s) freopen(s".in","r",stdin),freopen(s".out","w",stdout)
#define N 110
#define maxn 10010
#define maxm 1000010
#define zushu 4 using namespace std;
typedef long long llg; int p[zushu]={7757,11959,15121,20011},nn[N];
int n,m,l[N],mod,st[N],d[zushu][maxm],ld[zushu];
int ans[maxm],la,ci[maxm],nw[zushu];
char s[N][maxn];
bool fu[maxn<<1]; int getint(){
int w=0;bool q=0;
char c=getchar();
while((c>'9'||c<'0')&&c!='-') c=getchar();
if(c=='-') c=getchar(),q=1;
while(c>='0'&&c<='9') w=w*10+c-'0',c=getchar();
return q?-w:w;
} int suan(int x){
int ans=0,now=1;
for(int i=0;i<=n;i++){
ans+=nn[i]*now%mod,ans%=mod;
now*=x,now%=mod;
}
return ans;
} void work(){
for(int i=1;i<zushu;i++) nw[i]=1;
for(nw[0]=1;nw[0]<=ld[0];nw[0]++){
bool ww=1;
if(d[0][nw[0]]>m) break;
for(int i=1;i<zushu;i++){
while(d[i][nw[i]]<d[0][nw[0]]) nw[i]++;
if(d[i][nw[i]]!=d[0][nw[0]]) ww=0;
if(nw[i]>ld[i]) return;
}
if(ww) ans[++la]=d[0][nw[0]];
}
} int main(){
File("a");
n=getint(); m=getint();
for(int i=0;i<=n;i++){
scanf("%s",s[i]+1),l[i]=strlen(s[i]+1);
st[i]=(s[i][1]=='-'?2:1); fu[i]=(s[i][1]=='-');
}
for(int i=0;i<zushu;i++){
mod=p[i];
for(int j=0;j<=n;j++){
nn[j]=0;
for(int k=st[j];k<=l[j];k++) nn[j]=nn[j]*10+s[j][k]-'0',nn[j]%=mod;
if(fu[j]) nn[j]=-nn[j];
}
for(int j=0;j<mod;j++) if(!suan(j)) d[i][++ld[i]]=j;
for(int j=1;j<=ld[i];j++)
if(d[i][j]+mod<=m) d[i][++ld[i]]=d[i][j]+mod;
else break;
}
work();
printf("%d\n",la);
for(int i=1;i<=la;i++) printf("%d\n",ans[i]);
return 0;
}

  后天就是$noip$了,我现在还感觉有各种板子没有复习……感觉药丸……

  还有我在想我要不要也开一篇游记什么的……等我复习完了模板再说吧……也许我复习不完了。

vijos P1915 解方程 加强版的更多相关文章

  1. [NOIP2014] 解方程&加强版 (bzoj3751 & vijos1915)

    大概有$O(m)$,$O(n\sqrt{nm})$,$O(n\sqrt{m})$的3个算法,其中后2个可以过加强版.代码是算法3,注意bzoj的数据卡掉了小于20000的质数. #include< ...

  2. HDU 4793 Collision --解方程

    题意: 给一个圆盘,圆心为(0,0),半径为Rm, 然后给一个圆形区域,圆心同此圆盘,半径为R(R>Rm),一枚硬币(圆形),圆心为(x,y),半径为r,一定在圆形区域外面,速度向量为(vx,v ...

  3. codevs3732==洛谷 解方程P2312 解方程

    P2312 解方程 195通过 1.6K提交 题目提供者该用户不存在 标签数论(数学相关)高精2014NOIp提高组 难度提高+/省选- 提交该题 讨论 题解 记录   题目描述 已知多项式方程: a ...

  4. [NOIP2014]解方程

    3732 解方程  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题解       题目描述 Description 输入描述 Input Descrip ...

  5. bzoj 3751: [NOIP2014]解方程 同余系枚举

    3.解方程(equation.cpp/c/pas)[问题描述]已知多项式方程:a ! + a ! x + a ! x ! + ⋯ + a ! x ! = 0求这个方程在[1, m]内的整数解(n 和 ...

  6. Ural 1046 Geometrical Dreams(解方程+计算几何)

    题目链接:http://acm.timus.ru/problem.aspx?space=1&num=1046 参考博客:http://hi.baidu.com/cloudygoose/item ...

  7. 2017广东工业大学程序设计竞赛决赛 题解&源码(A,数学解方程,B,贪心博弈,C,递归,D,水,E,贪心,面试题,F,贪心,枚举,LCA,G,dp,记忆化搜索,H,思维题)

    心得: 这比赛真的是不要不要的,pending了一下午,也不知道对错,直接做过去就是了,也没有管太多! Problem A: 两只老虎 Description 来,我们先来放松下,听听儿歌,一起“唱” ...

  8. 5.5Python数据处理篇之Sympy系列(五)---解方程

    目录 目录 前言 (一)求解多元一次方程-solve() 1.说明: 2.源代码: 3.输出: (二)解线性方程组-linsolve() 1.说明: 2.源代码: 3.输出: (三)解非线性方程组-n ...

  9. python 解方程

    [怪毛匠子=整理] SymPy 库 安装 sudo pip install sympy x = Symbol('x') 解方程 solve([2 * x - y - 3, 3 * x + y - 7] ...

随机推荐

  1. PowerDesigner15在win7-64位系统下对MySQL 进行反向工程以及建立物理模型产生SQL语句步骤图文傻瓜式详解

    1.安装PowerDesigner15.MySQL5.不详细讲解了.网上一大把.请各位亲参考去. 2.安MyODBC-standard-3.51.0.7-win.msi.mysql-connector ...

  2. github指令

    一般用法 git stash git pull git stash pop 结局冲突 git add . git commit -m "message" git push 查看 g ...

  3. 原生JS:Function对象(apply、call、bind)详解

    Function对象(apply.call.bind) 原创文章,转摘请注明出处:苏福:http://www.cnblogs.com/susufufu/p/5850180.html 本文参考MDN做的 ...

  4. Android系统的五种数据存储形式(一)

    Android系统有五种数据存储形式,分别是文件存储.SP存储.数据库存储.contentprovider 内容提供者.网络存储.其中,前四个是本地存储.存储的类型包括简单文本.窗口状态存储.音频视频 ...

  5. Solr实现Low Level查询解析(QParser)

    Solr实现Low Level查询解析(QParser) Solr基于Lucene提供了方便的查询解析和搜索服务器的功能,可以以插件的方式集成,非常容易的扩展我们自己需要的查询解析方式.其中,Solr ...

  6. android性能优化练习:过度绘制

    练习:https://github.com/zhangbz/AndroidUIPorblems 查看过度绘制 在开发者选项中开启"调试GPU过度绘制" 判断标准 无色:没有过度绘制 ...

  7. 添加 All Exceptions 断点后, 每次运行都会在 main.m 中断的一种解决方法

    在本人项目添加导入和使用新的字体过程中,遇到一个很奇怪的问题: 项目开启了全局断点,但是每次启动都会运行在mian.m中断,点击下一步程序继续正常运行. 不知道是什么原因,于是google百度寻找答案 ...

  8. git rebase与 git合并(error: failed to push some refs to)解决方法

    1.遇到的问题 本地有一个git仓库,在github上新建了一个空的仓库,但是更新了REWADME.md的信息,即在github上多了一个提交. 关联远程仓库,操作顺序如下: git remote a ...

  9. 职业规划:管理vs技术

    "每个人都身怀天赋,但如果用会不会爬树能力来评判一只鱼,那它这辈子都会觉得自己是条蠢鱼" - 阿尔伯特.爱因斯坦 我想我为这篇博客已经准备了很长时间.但是看起了我还一直挣扎我该往哪 ...

  10. Linux安装DBI/DBD-ORACLE

    本文只是学习如何配置PERL DBI.PERL DBD时,整理的一个学习实践文档,大部分参考网上资料,详情请见下面参考资料. PERL对数据库的支持广而且全,几乎所有的主流数据库都有与之相应的PERL ...