n个数中找最大数c语言,N个数中找到第K大的数值(C语实现)

news/2024/10/18 2:31:24/

N个数中找到第K大的数值(C语实现)

N个数中找到第K大的数值(C语实现)

研究生了,选了计算机算法这门课程,这周布置了一个作业,在OJ上做:**N个数中找到第K大的数值**。大一简单学过C语言基础,目前只能用C语言编程,后续会学C++编程。

分享一份不超时的C语代码~

测试例子:

b490a1edd94da08f223a2daae20c0aa1.png

思路:

思路超简单,看到题目首先想到的就是先对N个数进行排序,再直接输出第K大的值即可。

1、最简单的方法就是冒泡排序(入门基础知识哈哈)

我试了下,成功超时了。因为冒泡排序要做的次数太多了,时间上还是不够的。代码如下:

#include

int main(void) {

int N,k;

int *a;//定义指针a

int i, j, t;

scanf("%d %d\n", &N, &k);

a=(int *)malloc(sizeof(int)*N);//定义一个baiint类型的指针变量dua,并申请zhin*sizeof(int)个字节(即4*n个字节)的dao存储空间。

for (i = 1; i <= N; i++)

scanf("%d", &a[i]);


http://www.ppmy.cn/news/714128.html

相关文章

c语言之标准(KRC 、c89、c99、c11)

K&R C 1978年&#xff0c;丹尼斯•里奇&#xff08;Dennis Ritchie&#xff09;和布莱恩•柯林汉&#xff08;Brian Kernighan&#xff09;合作出版了《C程序设计语言》的第一版。书中介绍的C语言标准也被C语言程式设计师称作“K&R C”&#xff0c;第二版的书中也包含了…

计算智能——K-means聚类算法C语言代码

K-means聚类算法 也称K均值聚类算法 是一种迭代求解的聚类分析算法&#xff0c;其步骤是随机选取K个对象作为初始的聚类中心&#xff0c;然后计算每个对象与各个种子聚类中心之间的距离&#xff0c;把每个对象分配给距离它最近的聚类中心。 1. K-Means原理 上图a表示最初的对象…

用c语言编写程序,求∑(k=1~100)k+∑(k=1~50)k2,c语言程序,求(100∑k=1 k)+(50∑k=1 k^2)+(10∑k=1 1/k) 这...

满意答案 myhso 2015.10.31 采纳率&#xff1a;54% 等级&#xff1a;8 已帮助&#xff1a;1060人 主函数main没有定义&#xff0c;在c语言中 两个整数相除返回整数 1/1 结果为 1 &#xff0c;1/2,1/3结果为0,所以 ss1/k要改为ss1.0/k ,最终的结果有小数 s不能定义为int整数&…

c语言全局变量SQR,c语言a/=SQR(k+m);是什么意思?

满意答案 NightmareJJ 2013.03.16 采纳率&#xff1a;47% 等级&#xff1a;12 已帮助&#xff1a;11233人 先看第一个 main() // 主函数 {printf("%ld\n", fun(3));} //输出fun(3)这个函数的返回值&#xff0c;3就是下一个 //函数中的n 值。 long fun (int n) //定…

【C语言】C语言实现矩阵k次幂 (模拟手工计算过程,简单逻辑)

运用递归实现k次幂运算&#xff0c;模拟手工计算 注释掉的输出部分便于调试过程中检查使用 使用说明&#xff1a;输入一个数字k&#xff0c;计算矩阵的k次幂&#xff0c;输出原矩阵以及其k次幂矩阵 矩阵的k次幂可用于以邻接矩阵存储的图的算法中&#xff0c;具体原理涉及到离…

5.21-----c语言冒泡排序--谁考了第K名

题目&#xff1a; 算法描述&#xff1a; 先创建2个数组&#xff0c;然后将学号&#xff0c;成绩都存在数组里面&#xff0c;然后里要冒泡排序法将学号&#xff0c;成绩按从小到大进行排序&#xff0c;然后输出第k名的成绩&#xff08;数组下标为k-1&#xff09;的。 #include&…

运用折半查找算法在一个有序数组中查找具体的某个数值k(c语言)

实现功能 在一个有序数组中&#xff0c;查找想要查找的某个具体数值。 如何实现 主要逻辑&#xff1a; 运用折半查找算法&#xff1a;设置中间值、左变量、右变量&#xff0c;通过比较大小不断将数组查找范围折半缩小&#xff0c;直至找到想要查找的数值k。 代码 #includ…

c语言将数组元素循环右移k位,把一个含有N个元素的数组循环右移K位

普通解法&#xff1a; 可以每次将数组中的元素右移一位&#xff0c;循环K次。每个元素右移N位后都会回到自己的位置上。因此&#xff0c;如果K > N&#xff0c;右移K-N之后的数组序列跟右移K位的结果是一样的。进而可得出一条通用的规律&#xff1a;右移K位之后的情形&#…