2019.7.8 校内测试题 牛数

2023-11-22 10:10
文章标签 校内 测试题 2019.7 牛数

本文主要是介绍2019.7.8 校内测试题 牛数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 题目

牛数(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.江湖救急算法

 

 

 

 

 

 

转载于:https://www.cnblogs.com/SeanOcean/p/11172593.html

这篇关于2019.7.8 校内测试题 牛数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/409396

相关文章

信息安全工程师模拟测试题

信息安全工程师:信息安全工程师证书属于软考中级资格证书之一,为了适应“十三五”期间计算机软件行业发展需要,满足社会多方对信息安全技术人员的迫切需求,信息安全工程师在2016年下半年首次开考,目前一年仅考一次。 信息安全工程师模拟测试题 一、基础知识二、软件应用 信息安全工程师 属于《国家职业资格目录(2021年版)》目录中的证书,通过考试将颁发由人社局和工信部盖章

大模型备案重难点最详细说明【评估测试题+附件】

2024年3月1日,我国通过了《生成式人工智能服务安全基本要求》(以下简称《AIGC安全要求》),这是目前我国第一部有关AIGC服务安全性方面的技术性指导文件,对语料安全、模型安全、安全措施、词库/题库要求、安全评估等方面提出了具体规范和要求。 (一)适用主体 《AIGC安全要求》的适用主体包括两类: 1. 生成式人工智能服务 定义:利用生成式人工智能技术向中华人民共和国境内公众提供生成文

C 测试题

 一、请填写BOOL , float,指针变量 与“零值”比较的 if语句。(10分)   请写出 BOOL flag 与“零值”比较的 if语句。(3分) 标准答案:     if ( flag )     if ( !flag ) 如下写法均属不良风格,不得分。    if (flag == TRUE)      if (flag == 1 )        if (f

面试3道测试题

1.题目:判断101-200之间有多少个素数,并输出所有素数。 判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数。 package interviewWjw;import java.util.ArrayList;import java.util.Iterator;import java.util.List;import java.

google校招在线测试题---2048

先附代码:(简单地说就是给出一个矩阵代表2048游戏的一个状态以及一个方向,输出往这个方向移动之后的矩阵) #include<iostream>#include<fstream>#include<string>using namespace std;int main(){int T;ifstream ifile("B-large-practice.in");ofstream ofil

如何用Java SpringBoot+Vue搭建校内跑腿业务系统?实战教程解析

✍✍计算机毕业编程指导师 ⭐⭐个人介绍:自己非常喜欢研究技术问题!专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目:有源码或者技术上的问题欢迎在评论区一起讨论交流! ⚡⚡ Java、Python、微信小程序、大数据实战项目集 ⚡⚡文末获取源码 文章目录 ⚡⚡文末获取源码校内跑腿业务系统-研究背景校内跑腿业务系统-技术校内跑腿

云计算期末综合测试题

云计算综合测试题 单选题填空题判断题简答题 单选题 这里选择题,直接以填空题展示,并给出解析 Bigtable是(Google)开发的分布式存储系统 解析:分布式结构化数据表Bigtable是Google基于GFS和Chubby开发的分布式存储系统。 WAS的存储名空间中,账户名负责将访问请求定位(集群) 解析:WAS(Windows Azure Stro

C++笔试题(一)【高级C++开发工程师综合测试题(风林火山)】

题目要求:代码要求能够直接编译运行(要求2个工作日完成) 1.       请实现一个函数:凑14;输入很多个整数(1<=数值<=13),任意两个数相加等于14就可以从数组中删除这两个数,求剩余数(按由小到大排列); 比如: 输入数组[9,1,9,7,5,13], 输出数组[7,9] 参考代码:整型数组处理算法(十三)请实现一个函数:凑14。[风林火山] 2.       请实

(各个公司面试原题)在线做了一套CC++综合测试题,也来测一下你的水平吧(一)

刚才又把做错的题看了看,感觉自己有太多的东西要补啊!!!         下面给出试题,和我对题目的一些理解 1.下面描述正确的是 int *p1 = new int[10]; int *p2 = new int[10](); A.   p1和p2申请的空间里面的值都是随机值 B.   p1和p2申请的空间里的值都已经初始化 C.   p1申请的空间里

高校三维地图校内导航系统

高校三维地图校内导航系统,三维图、平面图、航拍全景VR等多方位立体展示学校全貌,精准地位智能校内导航路线规划分析,打造智慧学校园平台。。。。。。 1、地图展示模式:2.5D地图模式 15-20层级瓦片数据 平面图模式  在线高德地图 全景图模式  航拍高空全景 2、地图基本操作:放大、缩小、平移、拖动、以及建筑信息和标注点信息展示功能。 3、建筑及标注点显示:在地图上可分层分级别显示