zoukankan      html  css  js  c++  java
  • luogu P2312 解方程

     

    题目描述

    已知多项式方程:

    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

    #include<algorithm>
    #include<iostream>
    #include<iomanip>
    #include<cstring>
    #include<cstdio>
    #include<cmath>
    using namespace std;
    typedef long long ll;
    const int p=1000000007;//取模比较方便qwq为了防止出现奇怪的错误建议多模几个质数 
    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)//输出优化(这个可以不加qwq) 
    {
        if(x<0)
        {
            putchar('-');
            x=-x;
        }
        if(x>9)
        {
            print(x/10);
        }
        putchar(x%10+'0');
    }
    bool calc(ll x)
    {
        sum=0;//一定要清零!!!(不然只有10分呜呜呜) 
        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;
    }
    

      

  • 相关阅读:
    Java数据结构之排序冒泡排序
    Java数据结构之单链表
    Java数据结构之排序选择排序
    Java基础之方法详解
    Java基础之数组类型
    linux/Unix下的vim/vi指令的使用方法
    如何在Ecplise调试之后恢复原来的界面
    Java数据结构之队列
    Java数据结构之排序插入排序
    开发部署带有自定义用户控件的WebPart全过程
  • 原文地址:https://www.cnblogs.com/lyqlyq/p/7582409.html
Copyright © 2011-2022 走看看