输出前 k 大的数

简介: 总时间限制: 10000ms 单个测试点时间限制: 1000ms 内存限制: 65536kB描述给定一个数组,统计前k大的数并且把这k个数从大到小输出。输入第一行包含一个整数n,表示数组的大小。
总时间限制: 10000ms 单个测试点时间限制: 1000ms 内存限制: 65536kB
描述

给定一个数组,统计前k大的数并且把这k个数从大到小输出。

输入
第一行包含一个整数n,表示数组的大小。n < 100000。
第二行包含n个整数,表示数组的元素,整数之间以一个空格分开。每个整数的绝对值不超过100000000。
第三行包含一个整数k。k < n。
输出
从大到小输出前k大的数,每个数一行。
样例输入
10
4 5 6 9 8 7 1 2 3 0
5
样例输出
9
8
7
6
5

分析:

按照快速排序的思想,把数组前k大的数放到数组末尾。然后在对数组末尾k个元素做排序再输出该部分元素。

 1 #include<stdio.h>
 2 #include<stdlib.h>
 3 
 4 int a[100010];
 5 
 6 int cmp(const void *a,const void *b)
 7 { return (*(int *)a) - (*(int *)b); }
 8 
 9 //将a[]数组下标区间[start,end]前k大的数放到数组下标在[start,end]范围的末尾部分.
10 void FindMaxK(int a[],int start,int End,int k)
11 {
12     if(start-End+1==k) return;//若是元素个数刚好就是k个,则可以直接返回. 
13     int i=start,j=End,key=a[start];
14     while(i<j)
15     {
16         while(i<j&&a[j]>=key) --j;
17         a[i]=a[j];
18         while(i<j&&a[i]<=key) ++i;
19         a[j]=a[i];
20     }
21     a[i]=key;
22     if(End-i+1==k) return;//数组后半段的元素个数为End-i+1,刚好够k个 
23     else if( End-i+1 > k) FindMaxK(a,i+1,End,k);//数组后半段的元素个数多于k个 
24     else FindMaxK(a,start,i-1,k-(End-i+1) );//数组后半段元素个数不够k个。所以要在前半段继续寻找k-(End-i+1)这么多个。 
25 }
26 int main()
27 {
28     int n,k;
29 
30     scanf("%d",&n);
31     for(int i = 0;i <n; ++i) scanf("%d",&a[i]);
32     scanf("%d",&k);
33     
34     FindMaxK(a,0,n-1,k);
35 
36     qsort(a+n-k,k,sizeof(a[0]),cmp);
37     for(int i = n-1;i >= n-k; --i) printf("%d\n",a[i]);
38     return 0;
39 }

 

C ++版:(北大郭炜老师)

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <algorithm>
 4 using namespace std;
 5 
 6 int a[100010];
 7 
 8 void swap(int & a,int & b)
 9 {  int tmp = a;  a = b;  b = tmp;  }
10 
11 //将a[]数组下标区间[start,end]前k大的数放到数组下标在[start,end]范围的末尾部分.
12 void FindMaxK(int a[],int start,int End,int k)
13 {
14     if(start-End+1==k) return;//若是元素个数刚好就是k个,则可以直接返回. 
15     int i=start,j=End,key=a[start];
16     while(i<j)
17     {
18         while(i<j&&a[j]>=key) --j;
19         swap(a[i],a[j]);
20         while(i<j&&a[i]<=key) ++i;
21         swap(a[i],a[j]);
22     }
23     if(End-i+1==k) return;//数组后半段的元素个数为End-i+1,刚好够k个 
24     else if( End-i+1 > k) FindMaxK(a,i+1,End,k);//数组后半段的元素个数多于k个 
25     else FindMaxK(a,start,i-1,k-(End-i+1) );//数组后半段元素个数不够k个。所以要在前半段继续寻找k-(End-i+1)这么多个。 
26 }
27 int main()
28 {
29     int n,k;
30     
31     scanf("%d",&n);
32     for(int i = 0;i <n; ++i) scanf("%d",&a[i]);
33     scanf("%d",&k);
34     
35     FindMaxK(a,0,n-1,k);
36 
37     sort(a+n-k-1,a+n);
38     for(int i = n-1;i >= n-k; --i)
39         printf("%d\n",a[i]);
40     return 0;
41 }

本问题可以参考阅读:

http://www.cnblogs.com/macher/p/5317439.html

http://www.cnblogs.com/huashanqingzhu/p/6591091.html

 

相关文章
|
开发工具
贤鱼的刷题日常----8469:特殊密码锁
讲解特殊密码锁,题目题解
254 0
贤鱼的刷题日常----8469:特殊密码锁
|
10天前
|
存储 关系型数据库 分布式数据库
PostgreSQL 18 发布,快来 PolarDB 尝鲜!
PostgreSQL 18 发布,PolarDB for PostgreSQL 全面兼容。新版本支持异步I/O、UUIDv7、虚拟生成列、逻辑复制增强及OAuth认证,显著提升性能与安全。PolarDB-PG 18 支持存算分离架构,融合海量弹性存储与极致计算性能,搭配丰富插件生态,为企业提供高效、稳定、灵活的云数据库解决方案,助力企业数字化转型如虎添翼!
|
9天前
|
存储 人工智能 Java
AI 超级智能体全栈项目阶段二:Prompt 优化技巧与学术分析 AI 应用开发实现上下文联系多轮对话
本文讲解 Prompt 基本概念与 10 个优化技巧,结合学术分析 AI 应用的需求分析、设计方案,介绍 Spring AI 中 ChatClient 及 Advisors 的使用。
410 130
AI 超级智能体全栈项目阶段二:Prompt 优化技巧与学术分析 AI 应用开发实现上下文联系多轮对话
|
3天前
|
存储 安全 前端开发
如何将加密和解密函数应用到实际项目中?
如何将加密和解密函数应用到实际项目中?
199 138
|
9天前
|
人工智能 Java API
AI 超级智能体全栈项目阶段一:AI大模型概述、选型、项目初始化以及基于阿里云灵积模型 Qwen-Plus实现模型接入四种方式(SDK/HTTP/SpringAI/langchain4j)
本文介绍AI大模型的核心概念、分类及开发者学习路径,重点讲解如何选择与接入大模型。项目基于Spring Boot,使用阿里云灵积模型(Qwen-Plus),对比SDK、HTTP、Spring AI和LangChain4j四种接入方式,助力开发者高效构建AI应用。
380 122
AI 超级智能体全栈项目阶段一:AI大模型概述、选型、项目初始化以及基于阿里云灵积模型 Qwen-Plus实现模型接入四种方式(SDK/HTTP/SpringAI/langchain4j)
|
3天前
|
存储 JSON 安全
加密和解密函数的具体实现代码
加密和解密函数的具体实现代码
198 136
|
21天前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1355 8
|
8天前
|
监控 JavaScript Java
基于大模型技术的反欺诈知识问答系统
随着互联网与金融科技发展,网络欺诈频发,构建高效反欺诈平台成为迫切需求。本文基于Java、Vue.js、Spring Boot与MySQL技术,设计实现集欺诈识别、宣传教育、用户互动于一体的反欺诈系统,提升公众防范意识,助力企业合规与用户权益保护。