首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    C语言 | 找出1000以内的所有完数

    例55:一个数如果恰好等于它的因子之和,这个数就称为完数,C语言编程找出1000之内的所有完数,并输出其因子。 ...解题思路:6的因子为1,2,3,而6=1+2+3,因此6是“完数”,1不用判断,直接从2开始,因为1的因子只有1 源代码演示: #include//头文件  int main()//主函数...number<1000;number++)//for循环    {     //直接从2开始     s=0;     for(i=1;i<number;i++)     {       //检查i是否是m的因子...:1 2 3 28的因子为:1 2 4 7 14 496的因子为:1 2 4 8 16 31 62 124 248 -------------------------------- Process exited...C语言 | 找出1000以内的所有完数 更多案例可以公众号:C语言入门到精通

    4.6K108

    找出数组中的第 K 大整数(排序)

    题目 给你一个字符串数组 nums 和一个整数 k 。 nums 中的每个字符串都表示一个不含前导零的整数。 返回 nums 中表示第 k 大整数的字符串。...示例 1: 输入:nums = ["3","6","7","10"], k = 4 输出:"3" 解释: nums 中的数字按非递减顺序排列为 ["3","6","7","10"] 其中第 4 大整数是..."3" 示例 2: 输入:nums = ["2","21","12","1"], k = 3 输出:"2" 解释: nums 中的数字按非递减顺序排列为 ["1","2","12","21"] 其中第...3 大整数是 "2" 示例 3: 输入:nums = ["0","0"], k = 2 输出:"0" 解释: nums 中的数字按非递减顺序排列为 ["0","0"] 其中第 2 大整数是 "0"...1]; } }; 576 ms 327.6 MB C++ ---- 我的CSDN博客地址 https://michael.blog.csdn.net/ 长按或扫码关注我的公众号(Michael阿明

    85330

    如何在 10 亿数中找出前 1000 大的数

    之前小史在 BAT 三家的面试中已经挂了两家,今天小史去了 BAT 中的最后一家面试了。 简单的自我介绍后,面试官给了小史一个问题。 ? 【面试现场】 ?...题目:如何在 10 亿数中找出前 1000 大的数? ? ? ? ? ? ? ? 小史:我可以用分治法,这有点类似快排中 partition 的操作。...随机选一个数 t,然后对整个数组进行 partition ,会得到两部分,前一部分的数都大于 t ,后一部分的数都小于 t 。 ? ?...如果前一部分的数小于 1000 个,那就在后一部分再进行 partition ,寻找剩下的数。 ? ? ? ? ? 小史:首先,partition 的过程,时间是 o(n)。...buildHeap(n, data); // n往后的数进行调整 for(int i = n; i < data.length; i++) {

    60920

    数组中第K小的数

    简介 查找一个序列中的最大/最小值时间复杂度均为 ,而查询一个序列中第 大的数时间复杂度最坏情况下即为排序的最好时间复杂度 只考虑比较排序),但利用快排的 思想也可以达到期望 的时间复杂度...然后判断: 如果枢轴左边小于等于枢轴的序列大小等于 ,则说明第 小的数即为枢轴。 如果枢轴左边小于等于枢轴的序列大小大于 ,则说明第 小的数一定在枢轴左边的序列。...{ return FindKth(mid+1,t,k+(s-mid)-1,cmp); } } // 查找第 k 大的数(随机化版本) template ...} else { return FindKth(gt+1,t,k-(gt-s+1),cmp); } } // 查找第 k 大的数(随机化版本) template <typename...} else { return FindKth(gt+1,t,k-(gt-s+1),cmp); } } // 查找第 k 大的数(随机化版本) template <typename

    1.1K20

    【面试必备】如何在10亿数中找出前1000大的数?

    简单的自我介绍后,面试官给了小史一个问题。 【面试现场】 题目:如何在10亿数中找出前1000大的数? 小史:我可以用分治法,这有点类似快排中partition的操作。...随机选一个数t,然后对整个数组进行partition,会得到两部分,前一部分的数都大于t,后一部分的数都小于t。 小史:如果说前一部分总数大于1000个,那就继续在前一部分进行partition寻找。...如果前一部分的数小于1000个,那就在后一部分再进行partition,寻找剩下的数。 小史:首先,partition的过程,时间是o(n)。...而n+n/2+n/4+...显然是小于2n的,所以这个方法的渐进时间只有o(n) (注:这里的时间复杂度计算只是简化计算版,真正严谨的数学证明可以参考算法导论相关分析。) 半分钟过去了。...小史:感悟还挺深的。虽然平时做过topN的问题,知道分治法时间更少。但是碰到具体问题的时候还是要具体分析,这种大数据量的情况下反而用堆会更快。 ?

    81530

    【面试现场】如何在10亿数中找出前1000大的数

    简单的自我介绍后,面试官给了小史一个问题。 ? 【面试现场】 ? 题目:如何在10亿数中找出前1000大的数? ? ? ? ? ? ? ?...小史:我可以用分治法,这有点类似快排中partition的操作。随机选一个数t,然后对整个数组进行partition,会得到两部分,前一部分的数都大于t,后一部分的数都小于t。...如果前一部分的数小于1000个,那就在后一部分再进行partition,寻找剩下的数。 ? ? ? ? ? 小史:首先,partition的过程,时间是o(n)。...而n+n/2+n/4+...显然是小于2n的,所以这个方法的渐进时间只有o(n) ? (注:这里的时间复杂度计算只是简化计算版,真正严谨的数学证明可以参考算法导论相关分析。) ? ? ?...buildHeap(n, data); // n往后的数进行调整 for(int i = n; i < data.length; i++) {

    40110

    【BAT面试必会】如何在10亿数中找出前1000大的数

    【面试现场】 题目:如何在10亿数中找出前1000大的数? ? ? ? ? ? ? ? 小史:我可以用分治法,这有点类似快排中partition的操作。...随机选一个数t,然后对整个数组进行partition,会得到两部分,前一部分的数都大于t,后一部分的数都小于t。 ? ?...如果前一部分的数小于1000个,那就在后一部分再进行partition,寻找剩下的数。 ? ? ? ? ? 小史:首先,partition的过程,时间是o(n)。...而n+n/2+n/4+...显然是小于2n的,所以这个方法的渐进时间只有o(n) ? (注:这里的时间复杂度计算只是简化计算版,真正严谨的数学证明可以参考算法导论相关分析。) ? ? ?...buildHeap(n, data); // n往后的数进行调整 for(int i = n; i < data.length; i++) {

    53710

    第K个最大的数+优化优先队列

    第K个最大的数 给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。 请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。...看看源码 private final static int max= 10^5 +1; //优先队列PQ //给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。...,把减少的部分尽量换成时间复杂度为O(1)的比较操作,这样假设有m次add,那么有(n-m)次比较,综合起来就是O(klogk)+O(n-k) 题目中要求第K个最大的数,数组长度是N,所以定义堆的时候大小为...K,然后用剩下的N-k个数和堆顶元素比较,最后堆顶即为结果: (1)如果K>2/N,最好做(N-K)次add操作。...第K个最大的数,就是第(N-K)个最小的数,因此用(N-K)大小的最大堆,堆顶就是结果。

    16710

    每日算法系列【LeetCode 719】找出第 k 小的距离对

    题目描述 给定一个整数数组,返回所有数对之间的第 k 个最小距离。一对 (A, B) 的距离被定义为 A 和 B 之间的绝对差值。...示例1 输入: nums = [1,3,1] k = 1 输出: 0 解释: 所有数对如下: (1,3) -> 2 (1,1) -> 0 (3,1) -> 2 因此第 1 个最小距离的数对是 (1,1)...那么我们可以从最大的差值开始,看是否有数对满足这个差值,并且这个差值还得是第 小的。对于差值 ,如果它是第 小的,说明所有数对中差值小于等于 的数对个数 一定大于等于 。...因为如果第 小的差值只有一个数对满足,那么 ,否则的话就有多个数对差值都是 ,那就有 。于是我们找到第一个满足 的差值就行了,再加 1 就是最终的答案。...代码 c++ class Solution { public: int smallestDistancePair(vector& nums, int k) { int

    54520

    面试必问:找出一组数中最小的K个数(海量数据Top K问题)

    题目 输入 n 个整数,找出其中最小的 k 个数。例如输入4、5、1、6、2、7、3、8 这8个数字,则最小的4个数字是1、2、3、4。...解法一:脱胎于快排的O(n)的算法 如果基于数组的第 k 个数字来调整,使得比第 k 个数字小的所有数字都位于数组的左边,比第 k 个数字大的所有数字都位于数组的右边。...解法二:适合处理海量数据的O(nlogk)的算法 我们可以先创建一个大小为K的数据容器来存储最小的 k 个数字,接下来我们每次从输入的 n 个整数中读入一个数。...找出这已有的 k 个数中的最大值,然后拿这次待插入的整数和最大值进行比较。...Top K 问题是在面试中经常被问到的问题,比如:从20亿个数字的文本中,找出最大的前100个。

    2.5K10
    领券