zoukankan      html  css  js  c++  java
  • [NOIP2014]解方程

    题目描述

    已知多项式方程:

    a0+a1x+a2x^2+..+anx^n=0

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

    输入输出格式

    输入格式:

    输入文件名为equation .in。

    输入共n + 2 行。

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

    接下来的n+1 行每行包含一个整数,依次为a0,a1,a2..an

    输出格式:

    输出文件名为equation .out 。

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

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

    输入输出样例

    输入样例#1: 
    2 10 
    1
    -2
    1
    输出样例#1: 
    1
    1
    输入样例#2: 
    2 10
    2
    -3
    1
    输出样例#2: 
    2
    1
    2
    输入样例#3: 
    2 10 
    1  
    3  
    2  
     
    输出样例#3: 
    0

    说明

    对于30%的数据:0<n<=2,|ai|<=100,an!=0,m<100

    对于50%的数据:0<n<=100,|ai|<=10^100,an!=0,m<100

    对于70%的数据:0<n<=100,|ai|<=10^10000,an!=0,m<10000

    对于100%的数据:0<n<=100,|ai|<=10^10000,an!=0,m<1000000

    思路

    30%数据暴力

    剩下数据用多个大指数取模(可避开高精度)

    枚举x的值出结果

    参考题解编程:

    #include<algorithm>
    #include<iostream>
    #include<iomanip>
    #include<cstring>
    #include<cstdio>
    #include<cmath>
    using namespace std;
    typedef long long ll;
    const int p=1000000007;//取模比较方便,建议多模几个质数 
    bool t=true;//用来判断是否有解 
    int n,m,ans,cnt,sum=0;//cnt记录解的个数;sum用来计算多项式的结果 
    int A[103],key[1000003];
    //A[]记录式中的a0,a1,a2(注意是以0为起点)
    //key记录每个解的值 
    ll read()//读入优化(似乎不加会T两个点w) 
    {
        ll sum=0,fg=1;
        char c=getchar();
        while(c < '0' || c > '9')
        {
            if(c=='-') fg=-1;//如果读到负号则记录 
            c=getchar();
        }
        while(c >='0' && c <='9')
        {
            sum=((sum*10)+c-'0')%p;
            //注意因为A[]可能很大,所以读入时就要进行取模操作 
            c=getchar();
        }
        return sum*fg;
        //如果是负数(fg==-1,即读到了负号)那么返回的值为负数 
    }
    void print(int x)//输出优化 
    {
        if(x<0)
        {
            putchar('-');
            x=-x;
        }
        if(x>9)
        {
            print(x/10);
        }
        putchar(x%10+'0');
    }
    bool calc(ll x)
    {
        sum=0;//一定要清零!!!
        for(ll i=n;i>=0;i--)
        {
            sum=((A[i]+sum)*x)%p;
            //这里套用秦九韶算法求多项式的值 
        }
        return !sum;//如果答案是0说明x值为该多项式的解,返回1(true) 
    }
    int main()
    {
        n=read();
        m=read();
        for(ll i=0;i<=n;i++)
        {
            A[i]=read();
        }
        for(ll i=1;i<=m;i++)
        {
            if(calc(i))//如果返回的是1(true)则说明有解 
            { 
                t=false; +
                ans++;//记录答案个数 
                key[++cnt]=i;//记录每个解的值 
            }
        }
        if(t)
        {
            cout<<ans<<endl;//如果t未改变则说明解的个数为0 
            return 0;
        }
        print(ans);
        printf("
    ");
        for(ll i=1;i<=cnt;i++)
        {
            print(key[i]);
            printf("
    ");
        }
        return 0;
    }
  • 相关阅读:
    (转)Scrapy 深入一点点
    解决Scrapy shell启动出现UnicodeEncodeError问题
    js回调方法
    UGUI 之 控件以及按钮的监听事件系统 存档
    重力感应示例
    网格概念
    Flash Player11异步解码Bitmap
    打包包含已修改过的bug
    ios7官方推荐icon尺寸
    项目资源通过swc获取
  • 原文地址:https://www.cnblogs.com/wisdom-jie/p/7719798.html
Copyright © 2011-2022 走看看