ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

2019.7.8 校内测试题 牛数

2019-07-11 20:55:20  阅读:324  来源: 互联网

标签:牛数 cow 测试题 int FORa 2019.7 read pa buf


 题目

  牛数(cow.cpp,1s,128MB)

【问题描述】:

  我们下面来研究整数性质,我们知道质数只有 1 和自身两个因子,合数至少 有除了 1 和自身的其他因子,我们也知道“猫老大数”是只能分解成两个质数乘 积形式的数,那么能分解成两个合数的数呢?我们称之为“牛数”。下面编程判 断整数是否为“牛数”。

【输入文件】:

   第一行为 t(1≤t≤1000),表示测试数据组数。

  接下来 t 行,每行一个正整数 x。

【输出文件】:

  对于每个输入数据 x,判断它是否为“牛数”,并输出一行字符串:如果它

是“牛数”,输出“cow”,否则输出“no”。

【输入输出样例】:

  cow.in     2     15     36   cow.out     no     cow

【数据规模】:

  60%的数据:1≤x≤10^9

  100%的数据:1≤x≤10^12

 

 

考试得分:  0

 

 

主要算法 :  质数(质因数分解)

 

 

 

题干:

    质因数分解板子

 

 

应试策略:

  筛选出质数,尽量减小时间复杂度,然后模拟

   代码

 

#include<map>
#include<math.h>
#include<stdio.h>
#include<stdlib.h>
#define FORa(i,s,e) for(int i=s;i<=e;i++)
#define FORs(i,s,e) for(int i=s;i>=e;i--)
#define gc pa==pb&&(pb=(pa=buf)+fread(buf,1,10000,stdin),pa==pb)?EOF:*pa++
#define File(name) freopen(name".in","r",stdin),freopen(name".out","w",stdout)

using namespace std;
static char buf[10000],*pa=buf,*pb=buf;
inline int read();

const int T=1000,N=1000000;
int Maxn,n,t[T+1],prime[N+1],v[N+1],cnt;

map<int,bool> mp;
bool Solve(int tt)
{
    FORa(i,2,sqrt(tt))
    {
        if(tt%i==0&&!mp[i])
        {
            int p=tt/i;
            FORa(j,2,sqrt(p)) if(p%j==0) return 1;    
        }
    }
    return 0;
}
int main()
{
    File("cow");
    n=read();
    FORa(i,1,n) t[i]=read(),Maxn=Maxn>t[i]?Maxn:t[i];
    FORa(i,2,Maxn)
    {
        if(!v[i]) v[i]=i,prime[++cnt]=i;
        FORa(j,1,cnt)
        {
            if(prime[j]>v[i]||prime[j]*i>Maxn) break;
            v[prime[j]*i]=prime[j];
        }
    }
    FORa(i,1,cnt) mp[prime[i]]=1;
    FORa(i,1,n) Solve(t[i])?printf("cow\n"):printf("no\n");
    return 0;
}
inline int read()
{
    register int x(0);register int f(1);register char c(gc);
    while(c<'0'||c>'9') f=c=='-'?-1:1,c=gc;
    while(c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=gc;
    return x*f;
}

 

 

 

 

 

非完美算法:  

    照搬应试策略

 

 

正解:

  质因数个数判定

  代码

  

#include<math.h>
#include<stdio.h>
#include<stdlib.h>
#define LL long long
#define FORa(i,s,e) for(LL i=s;i<=e;i++)
#define FORs(i,s,e) for(LL i=s;i>=e;i--)
#define gc getchar()//pa==pb&&(pb=(pa=buf)+fread(buf,1,10000,stdin),pa==pb)?EOF:*pa++
#define File(name) freopen(name".in","r",stdin),freopen(name".out","w",stdout)

using namespace std;
static char buf[10000],*pa=buf,*pb=buf;
inline LL read();

LL n,t,ans;

int main()
{
    File("cow");
    n=read();
    FORa(i,1,n)
    {
        t=read(),ans=0;
        FORa(j,2,sqrt(t)) 
        {
            while(t%j==0) 
            {    
                t/=j,ans++;        
                if(ans>=4) break;
            }    
            if(ans>=4) break;
        }
        if(t>1) ans++;
        (ans>=4)?printf("cow\n"):printf("no\n"); 
    } 
    return 0;
}
inline LL read()
{
    register LL x(0);register LL f(1);register char c(gc);
    while(c<'0'||c>'9') f=c=='-'?-1:1,c=gc;
    while(c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=gc;
    return x*f;
}

 

 

 

 

总结:

  1.注意最后除完的数是否是一个质数
  2.江湖救急算法

 

 

 

 

 

 

标签:牛数,cow,测试题,int,FORa,2019.7,read,pa,buf
来源: https://www.cnblogs.com/SeanOcean/p/11172593.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有