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. Field 'email' doesn't have a default value

    MySQL在出现这个Field xxx doesn't have a default value错误的原因是:我们设置了该字段为非空,但是我们没有设置默认值造成的. 或着 缺少字段.

  2. 接口自动化学习--mock

    好久没有写学习的总结,都正月十二了,但还是要来个新年快乐鸭. 一直都在看imooc的一套java接口自动化实战课程,现在看到了尾部了,然后想到之前那些testng,mock,httpclient等都没 ...

  3. Python3列表中获取相同元素出现位置的下标

    前言 list: Python3的列表类型, 和其他语言中的数组类似 定义格式: l = ["a", "b", "c", "a&q ...

  4. Controller层@PathVariable使用

    @PathVariable 映射 URL 绑定的占位符 带占位符的 URL 是 Spring3.0 新增的功能,该功能在SpringMVC 向 REST 目标挺进发展过程中具有里程碑的意义通过 @Pa ...

  5. Python 循环的技巧

    当在字典中循环时,用 items() 方法可将关键字和对应的值同时取出 >>> knights = {'gallahad': 'the pure', 'robin': 'the br ...

  6. VM虚拟机系统时间同步网络时间并登录用户自动校正时间

    原文出处: http://blog.51cto.com/wutou/1932317 VM虚拟机大家都用,我在用完后,经常使用"挂起客户机",但是这样一来,系统恢复启动很快,但是少了 ...

  7. GitHub笔记(二)——远程仓库的操作

    二 远程仓库 1 创建联系 第1步:创建SSH Key.在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有id_rsa和id_rsa.pub这两个文件,如果已经有了,可直接跳到下一 ...

  8. RBC:Echo设备2020年可为亚马逊贡献100亿美元收入

    BI 中文站 12 月 22 日报道 加拿大皇家银行资本市场(RBC Capital Markets)分析师马克-马哈尼(Mark Mahaney)表示,亚马逊是首批将智能音箱引进主流受众的公司之一, ...

  9. 浏览器差异bug汇总(js篇)

    获取滚动条高度 var scrollTop = document.body.scrollTop || document.documentElement.scrollTop; safari浏览器时间函数 ...

  10. VS2010+WinXP+MFC程序 无法定位程序输入点于动态链接库

    1.问题描述 原开发环境:Win7 64位旗舰版,VS2010,ThinkPad T460 出现问题:自己开发的MFC程序在WinXP环境下无法正常运行,弹框“无法定位程序输入点InitializeC ...