emmm...不能说是水题吧...小金羊以为考的是STL(手动滑稽)...

行,这个题说让分解因数(不一定非得质因数)。

我们考虑到有第k个数有可能有\(x\cdot x=n\)的毒瘤情况,

并且题目明确要求说从小到大

——set帮助你轻松水过去。

emmm....题目范围说是

\[1\leq n\leq 10^{15},1\leq k\leq 10^9
\]

很明显朴素算法炸了!

我们需要知道\(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】的更多相关文章

  1. 【题解】K乘积

    题目描述 有N个数,每个数的范围是[-50,50],现在你要从这N个数中选出K个,使得这K个数的乘积最大. 输入格式 第一行,N和K. 1 <= N <= 50.  1 <= K & ...

  2. 题解——UVA11997 K Smallest Sums

    题面 背景 输入 输出 翻译(渣自翻) 给定K个包含K个数字的表,要求将其能产生的\( k^{k} \)个值中最小的K个输出出来 题解 k路归并问题的经典问题 可以转化为二路归并问题求解 考虑A[], ...

  3. 题解-Atcoder_agc005D ~K Perm Counting

    Problem AtCoder-agc005D 题意概要:给出\(n,k\),求合法的排列个数,其中合法定义为任何数字所在位置与自身值差的绝对值不为\(k\)(即求排列\(\{A_i\}\),使得\( ...

  4. [LeetCode 题解]: Merge k Sorted Lists

    Merge k sorted linked lists and return it as one sorted list. Analyze and describe its complexity. 题 ...

  5. leecode 题解 || Merge k Sorted Lists 问题

    problem: Merge k sorted linked lists and return it as one sorted list. Analyze and describe its comp ...

  6. [codevs1157]2^k进制数

    [codevs1157]2k进制数 试题描述 设r是个2k 进制数,并满足以下条件: (1)r至少是个2位的2k 进制数. (2)作为2k 进制数,除最后一位外,r的每一位严格小于它右边相邻的那一位. ...

  7. 2016ACM-ICPC Qingdao Online青岛网络赛题解

    TonyFang+Sps+我=5/12 滚了个大粗 2016年9月21日16:42:36 10题完工辣 01 题意:求形同的数中大于n的最小值 题解:预处理所有的(5194个),在这里面二分 #inc ...

  8. Codevs1992题解

    题目大意 求有向图中经过某一点k的最大环(数据规模不支持floyd). 题解 以k为起点在正向图中spfa求单源最短路.再在反向图中spfa求单源最短路. 枚举除k外的每个点i.假设有一个同一时候包括 ...

  9. AGC030 简要题解

    A - Poisonous Cookies 题意 有\(A\)个能解毒的普通饼干,\(B\)个能解毒的美味饼干,\(C\)个有毒的美味饼干,求最多能吃多少个美味饼干,每次吃完有毒的饼干后要解毒后才能继 ...

随机推荐

  1. Win10家庭版无法打开策略组问题

    Win10家庭版无法打开策略组问题 • 复制以下代码至记事本中 @echo off pushd "%~dp0" *.mum >List.txt *.mum >>L ...

  2. yum指令常用参数说明

    1.使用YUM查找软件包 命令:yum search 2.列出所有可安装的软件包 命令:yum list 3.列出所有可更新的软件包 命令:yum list updates 4.列出所有已安装的软件包 ...

  3. Keycloak服务器安装和配置

    安装地址:https://www.keycloak.org/archive/downloads-4.4.0.html 参考文档:https://www.keycloak.org/docs/latest ...

  4. Netty源码分析第4章(pipeline)---->第5节: 传播outbound事件

    Netty源码分析第五章: pipeline 第五节: 传播outBound事件 了解了inbound事件的传播过程, 对于学习outbound事件传输的流程, 也不会太困难 在我们业务代码中, 有可 ...

  5. Mysql读写分离——主从数据库+Atlas

    mysql集群 最近在参加项目开发微信小程序后台,由于用户数量巨大,且后台程序并不是很完美,所以对用户的体验很是不友好(简单说就是很卡).赶巧最近正在翻阅<大型网站系统与Java中间件实践> ...

  6. 工具 | Sublime

    Sublime 前言 妈耶..\(Sublime\)的界面真的是太好看啦哭哭.. 我永远喜欢Sublime! 强推Sublime... 正文 自从暑假用上的Ubontu 一开始用的是\(gedit\) ...

  7. IOS git 删除仓库 新建仓库 提交 合并 操作 码云

    HDHaoShaoPengdeiMac:~ hdhaoshaopeng$ defaults write com.apple.finder AppleShowAllFiles TRUE HDHaoSha ...

  8. Vue 事件处理

    原生的js事件处理 原生的js事件处理,可以分为:直接内联执行代码,或者绑定事件函数. 在内联的事件处理函数内部或者事件绑定的方法内部的作用域中的this都是指向当前的dom对象.如何在vue绑定的元 ...

  9. Vue 入门之概念

    Vue 简介 Vue 是一个前端的双向绑定类的框架,发音[读音 /vjuː/, 类似于 [view].新的 Vue 版本参考了 React 的部分设计,当然也有自己独特的地方,比如 Vue 的单文件组 ...

  10. linux后退文件夹命令

    后退文件夹: cd -  在重复一遍就是前进了