今天难得做了做洛谷的题,而且还是两个!

P1075:已知正整数n是两个不同的质数的乘积,试求出两者中较大的那个质数。输入格式:一个正整数n。输出格式:一个正整数p,即较大的那个质数。

第一版代码:

#include<iostream>
using namespace std;
bool isZhi(int a)
{
if(a==)return false;
for(int i=;i<a;i++)
{
if(a%i==)return false;
}
return true;
}
int main()
{
int n;
cin>>n;
for(int x=n-;x>;x--)
{
if(isZhi(x)==true&&n%x==)
{
cout<<x;
break;
}
}
}

很简单,判断质数的程序已经讲过很多遍了。main函数中,从n-1往下减,如果遇到一个既是质数又能整除原数的数,就输出并停止。这样能保证输出的唯一质因数是最大的。

然而,交了代码以后,分数才刚好及格,未通过的4个监测点都超时了。

怎么会超时呢?我想了想。能不能让for循环检测的少一点?

对了!为什么非得检测到1?如果检测到n的平方根再往下检测,那么即使出现了质因数,它也不是最小的了!

第二版代码:

#include<iostream>
#include<cmath>
using namespace std;
bool isZhi(int a)
{
if(a==)return false;
for(int i=;i<a;i++)
{
if(a%i==)return false;
}
return true;
}
int main()
{
int n;
cin>>n;
for(int x=n-;x>=sqrt(n);x--)
{
if(isZhi(x)==true&&n%x==)
{
cout<<x;
break;
}
}
}

先引用cmath库以调用sqrt函数。然后按照我的思路检测,完美!

然而还是超时了。。。。。。

我又一次考虑起来。能不能让检测质数的函数精简一些?

对了!函数中的迭代器i如果超过了a/2,那么就不用再加了!直接就可以判断是质数!因为i如果大于a/2,那么a/i将小于2.

第三版代码:

#include<iostream>
#include<cmath>
using namespace std;
bool isZhi(int a)
{
if(a==)return false;
for(int i=;i<=a/;i++)
{
if(a%i==)return false;
}
return true;
}
int main()
{
int n;
cin>>n;
for(int x=n-;x>=sqrt(n);x--)
{
if(isZhi(x)==true&&n%x==)
{
cout<<x;
break;
}
}
}

然而,又一次超时了。。。

那就是处理器的问题了!我磕碜的i3-7100真的虚了,人家i7,i9的一大片,可是我家穷其实是我妈kou men能怪我吗!

人间不值得

P1138:题目描述

现有n个正整数,n≤10000,要求出这n个正整数中的第k个最小整数(相同大小的整数只计算一次),k≤1000,正整数均小于30000。输入格式:

第一行为n和k; 第二行开始为n个正整数的值,整数间用空格隔开。输出格式:

第k个最小整数的值;若无解,则输出“NO RESULT”。注意这里,一会真香

学了排序的我想了想,桶排序应该是最好的。因为相同大小的整数只计算一次。冒泡排序最大的缺点就是不能有相同数据,否则会出来很乱的结果正好选择排序我没学好,其他排序根本不会,于是我试了试:

第一版:

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int toConst(int a)
{
const int A=a;
return A;
}
int b[];
int main()
{
//桶排序
int n,k;
memset(b,,sizeof(b));
cin>>n>>k;
int a[toConst(n)];
for(int i=;i<n;i++)
{
cin>>a[i];
b[a[i]]++;//标号为输入数据的桶,桶号即数据,桶中的值为是否有这个数据。
}
for(int i=;i<;i++)
{
if(b[i]>)
{
if(k==i+)//第i个有数据的桶,正好是第k个时
{
cout<<i;
return ;
}
}
}
cout<<"NO ANSWER";
}

桶排序的思路请参见一本通我自己也讲不明白。

然而错了!

我想了想,其实最后一个注释本来就不对。i是迭代器,它只负责找桶。应当是每找到一个桶,一个变量递增,说明找到了第某个桶。当这个变量正好为k时输出这个桶的下标(即i).不能把i直接拿过来用。

第二版:

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int toConst(int a)
{
const int A=a;
return A;
}
int b[];
int main()
{
//桶排序
int n,k;
int p=;//检测有数据的桶数
memset(b,,sizeof(b));
cin>>n>>k;
int a[toConst(n)];
for(int i=;i<n;i++)
{
cin>>a[i];
b[a[i]]++;
}
for(int i=;i<;i++)
{
if(b[i]>)
{
p++;//有数据
if(k==p)
{
cout<<i;
return ;
}
}
}
cout<<"NO ANSWER";
}

不错不错!

然而。。。成绩和上次一样!

怎么回事?哪里都没问题啊!

我悄悄看了看原题,瞥见了"NO RESULT",有看了看我的"NO ANSWER".......

哦豁!我几乎叫了起来!我怎么犯了这种错误!

第三版:

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int toConst(int a)
{
const int A=a;
return A;
}
int b[];
int main()
{
//桶排序
int n,k;
int p=;
memset(b,,sizeof(b));
cin>>n>>k;
int a[toConst(n)];
for(int i=;i<n;i++)
{
cin>>a[i];
b[a[i]]++;
}
for(int i=;i<;i++)
{
if(b[i]>)
{
p++;
if(k==p)
{
cout<<i;
return ;
}
}
}
cout<<"NO RESULT";//没什么好说的了
}

人间不值得(前后照应)

P1075,P1138(洛谷)的更多相关文章

  1. 洛谷1640 bzoj1854游戏 匈牙利就是又短又快

    bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...

  2. 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.

    没有上司的舞会  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond       题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...

  3. 洛谷P1108 低价购买[DP | LIS方案数]

    题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买:再低价购买”.每次你购买一支股票,你必须用低于你上次购买它的价格购买它 ...

  4. 洛谷 P2701 [USACO5.3]巨大的牛棚Big Barn Label:二维数组前缀和 你够了 这次我用DP

    题目背景 (USACO 5.3.4) 题目描述 农夫约翰想要在他的正方形农场上建造一座正方形大牛棚.他讨厌在他的农场中砍树,想找一个能够让他在空旷无树的地方修建牛棚的地方.我们假定,他的农场划分成 N ...

  5. 洛谷P1710 地铁涨价

    P1710 地铁涨价 51通过 339提交 题目提供者洛谷OnlineJudge 标签O2优化云端评测2 难度提高+/省选- 提交  讨论  题解 最新讨论 求教:为什么只有40分 数组大小一定要开够 ...

  6. 洛谷P1371 NOI元丹

    P1371 NOI元丹 71通过 394提交 题目提供者洛谷OnlineJudge 标签云端评测 难度普及/提高- 提交  讨论  题解 最新讨论 我觉得不需要讨论O long long 不够 没有取 ...

  7. 洛谷P1538迎春舞会之数字舞蹈

    题目背景 HNSDFZ的同学们为了庆祝春节,准备排练一场舞会. 题目描述 在越来越讲究合作的时代,人们注意的更多的不是个人物的舞姿,而是集体的排列. 为了配合每年的倒计时,同学们决定排出——“数字舞蹈 ...

  8. 洛谷八月月赛Round1凄惨记

    个人背景: 上午9:30放学,然后因为学校举办读书工程跟同学去书城选书,中午回来开始打比赛,下午又回老家,中间抽出一点时间调代码,回家已经8:50了 也许是7月月赛时“连蒙带骗”AK的太幸运然而因同学 ...

  9. 洛谷 P1379 八数码难题 Label:判重&&bfs

    特别声明:紫书上抄来的代码,详见P198 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给 ...

随机推荐

  1. PowerShell 通过 WMI 获取系统服务

    本文告诉大家如何通过 WMI 获取系统服务 通过 Win32_Service 可以获取系统启动的服务 Get-WmiObject Win32_Service | Format-List Caption ...

  2. hadoop常用端口及定义方法

    hadoop2.x常用到的组件:HDFS, YARN, HBase, Hive, ZooKeeper: 组件 节点 默认端口 配置 用途说明HDFS DataNode 50010 dfs.datano ...

  3. python关于MySQL的API -- pymysql模块

    1.模块安装 pip install pymysql 2.执行sql语句 import pymysql #添加数据 conn = pymysql.connect(host='127.0.0.1', p ...

  4. Docker 说明

    一.Docker 是什么? 1.为什么会有 Docker 出现 ? 一款产品从开发到上线,从操作系统,到运行环境,再到应用配置.作为开发+运维之间的协作我们需要关心很多东西,这也是很多互联网公司都不得 ...

  5. switch多值匹配骚操作,带你涨姿势!

    我们都知道 switch 用来走流程分支,大多情况下用来匹配单个值,如下面的例子所示: /** * @from 微信公众号:Java技术栈 * @author 栈长 */ private static ...

  6. FPM简介(定制rpm包)

    FPM简介 fpm是生成rpm包的工具.rpm包的制作,采用fpm工具完成,FPM非常易用,此命令可以把rpm包的安装.卸载做得更加优雅,在安装前可以做一些准备工作,安装后可以做一些收尾工作,在卸载前 ...

  7. 【一起学源码-微服务】Ribbon 源码二:通过Debug找出Ribbon初始化流程及ILoadBalancer原理分析

    前言 前情回顾 上一讲讲了Ribbon的基础知识,通过一个简单的demo看了下Ribbon的负载均衡,我们在RestTemplate上加了@LoadBalanced注解后,就能够自动的负载均衡了. 本 ...

  8. 机器学习实战笔记(一)- 使用SciKit-Learn做回归分析

    一.简介 这次学习的书籍主要是Hands-on Machine Learning with Scikit-Learn and TensorFlow(豆瓣:https://book.douban.com ...

  9. day5 函数和参数

    函数就是最基本的一种代码抽象的方式 定义一个函数使用def语句 def my_abs(x): if x >= 0: return x else: return -x 定义一个什么事也不做的空函数 ...

  10. docker-管理数据

    管理Docker中的数据 默认情况下,在容器内创建的所有文件都存储在可写容器层中.这意味着: 当该容器不再运行时,数据不会持久存在,如果另一个进程需要,则可能很难从容器中获取数据. 容器的可写层紧密耦 ...