题解 CF762A 【k-th divisor】
emmm...不能说是水题吧...小金羊以为考的是STL(手动滑稽)...
行,这个题说让分解因数(不一定非得质因数)。
我们考虑到有第k个数有可能有\(x\cdot x=n\)的毒瘤情况,
并且题目明确要求说从小到大
——set帮助你轻松水过去。
emmm....题目范围说是
\]
很明显朴素算法炸了!
我们需要知道\(x\cdot y=n\)的时候\(x\leq\sqrt{n}\),两侧同时平方,得到\(x^2\leq n\)。
省下一大笔时间。
去重和排序、排名的工作留给set,我们只需要往里面插入元素就好了。
再说一下setのrank(第k个)的原理:
set自建一颗R-B T(Red-Black Tree),是平衡二叉搜索树,二叉搜索树嘛,rank是其基本算法原理。平衡让其效率更高,让两侧子树尽量平衡元素个数,避免长链的出现。
最后本题解还要说明setiterator(迭代器)的本题用法:
迭代器就是一个集合形式的指针,指向特定容器的某一元素。
但是迭代器不能像指针一样+-×÷,c++ 11的标准好像只支持++或者--。
如果k大于set内部元素个数,就输出-1。如果小于等于,就把iterator移动到
指向k-th个元素上就行。
Code:
#include <iostream>
#include <cstdio>
#include <set>//set库
using namespace std;
typedef unsigned long long int ulli;//毒瘤数据
set<ulli>divisors;
set<ulli>::iterator iter;
void divide(ulli num)
{
for (register ulli i=1;i*i<=num;i++)
{
if (num%i==0)
{
divisors.insert(i);//把x压入set
divisors.insert(num/i);//把另一半也压进去
}
}
}
int main()
{
ulli num,k;
cin>>num>>k;
divide(num);
if (k>divisors.size())//范围超出
{
printf("-1");
}
else
{
iter=divisors.begin();//使其指向容器的第一个元素
for (register ulli i=1;i<=k-1;i++,iter++/*仅能使用++*/)
{;}//挪动器(手动滑稽)
cout<<*iter;//注意输出的时候要加上*
}
return 0;
}
实在是看不懂楼上的码风,就发一篇题解方便大家理解。
不会告诉你们一开始输出%d来着
最多一个点177ms,836kB,能接受的范围之内。
题解 CF762A 【k-th divisor】的更多相关文章
- 【题解】K乘积
题目描述 有N个数,每个数的范围是[-50,50],现在你要从这N个数中选出K个,使得这K个数的乘积最大. 输入格式 第一行,N和K. 1 <= N <= 50. 1 <= K & ...
- 题解——UVA11997 K Smallest Sums
题面 背景 输入 输出 翻译(渣自翻) 给定K个包含K个数字的表,要求将其能产生的\( k^{k} \)个值中最小的K个输出出来 题解 k路归并问题的经典问题 可以转化为二路归并问题求解 考虑A[], ...
- 题解-Atcoder_agc005D ~K Perm Counting
Problem AtCoder-agc005D 题意概要:给出\(n,k\),求合法的排列个数,其中合法定义为任何数字所在位置与自身值差的绝对值不为\(k\)(即求排列\(\{A_i\}\),使得\( ...
- [LeetCode 题解]: Merge k Sorted Lists
Merge k sorted linked lists and return it as one sorted list. Analyze and describe its complexity. 题 ...
- leecode 题解 || Merge k Sorted Lists 问题
problem: Merge k sorted linked lists and return it as one sorted list. Analyze and describe its comp ...
- [codevs1157]2^k进制数
[codevs1157]2k进制数 试题描述 设r是个2k 进制数,并满足以下条件: (1)r至少是个2位的2k 进制数. (2)作为2k 进制数,除最后一位外,r的每一位严格小于它右边相邻的那一位. ...
- 2016ACM-ICPC Qingdao Online青岛网络赛题解
TonyFang+Sps+我=5/12 滚了个大粗 2016年9月21日16:42:36 10题完工辣 01 题意:求形同的数中大于n的最小值 题解:预处理所有的(5194个),在这里面二分 #inc ...
- Codevs1992题解
题目大意 求有向图中经过某一点k的最大环(数据规模不支持floyd). 题解 以k为起点在正向图中spfa求单源最短路.再在反向图中spfa求单源最短路. 枚举除k外的每个点i.假设有一个同一时候包括 ...
- AGC030 简要题解
A - Poisonous Cookies 题意 有\(A\)个能解毒的普通饼干,\(B\)个能解毒的美味饼干,\(C\)个有毒的美味饼干,求最多能吃多少个美味饼干,每次吃完有毒的饼干后要解毒后才能继 ...
随机推荐
- Win10家庭版无法打开策略组问题
Win10家庭版无法打开策略组问题 • 复制以下代码至记事本中 @echo off pushd "%~dp0" *.mum >List.txt *.mum >>L ...
- yum指令常用参数说明
1.使用YUM查找软件包 命令:yum search 2.列出所有可安装的软件包 命令:yum list 3.列出所有可更新的软件包 命令:yum list updates 4.列出所有已安装的软件包 ...
- Keycloak服务器安装和配置
安装地址:https://www.keycloak.org/archive/downloads-4.4.0.html 参考文档:https://www.keycloak.org/docs/latest ...
- Netty源码分析第4章(pipeline)---->第5节: 传播outbound事件
Netty源码分析第五章: pipeline 第五节: 传播outBound事件 了解了inbound事件的传播过程, 对于学习outbound事件传输的流程, 也不会太困难 在我们业务代码中, 有可 ...
- Mysql读写分离——主从数据库+Atlas
mysql集群 最近在参加项目开发微信小程序后台,由于用户数量巨大,且后台程序并不是很完美,所以对用户的体验很是不友好(简单说就是很卡).赶巧最近正在翻阅<大型网站系统与Java中间件实践> ...
- 工具 | Sublime
Sublime 前言 妈耶..\(Sublime\)的界面真的是太好看啦哭哭.. 我永远喜欢Sublime! 强推Sublime... 正文 自从暑假用上的Ubontu 一开始用的是\(gedit\) ...
- IOS git 删除仓库 新建仓库 提交 合并 操作 码云
HDHaoShaoPengdeiMac:~ hdhaoshaopeng$ defaults write com.apple.finder AppleShowAllFiles TRUE HDHaoSha ...
- Vue 事件处理
原生的js事件处理 原生的js事件处理,可以分为:直接内联执行代码,或者绑定事件函数. 在内联的事件处理函数内部或者事件绑定的方法内部的作用域中的this都是指向当前的dom对象.如何在vue绑定的元 ...
- Vue 入门之概念
Vue 简介 Vue 是一个前端的双向绑定类的框架,发音[读音 /vjuː/, 类似于 [view].新的 Vue 版本参考了 React 的部分设计,当然也有自己独特的地方,比如 Vue 的单文件组 ...
- linux后退文件夹命令
后退文件夹: cd - 在重复一遍就是前进了