博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PAT 基础编程题 4-11 求自定类型元素序列的中位数(希尔排序)
阅读量:4611 次
发布时间:2019-06-09

本文共 936 字,大约阅读时间需要 3 分钟。

4-11 求自定类型元素序列的中位数   (25分)

本题要求实现一个函数,求N个集合元素A[]的中位数,即序列中第\lfloor N/2 +1\rfloorN/2+1大的元素。其中集合元素的类型为自定义的ElementType

函数接口定义:

ElementType Median( ElementType A[], int N );

其中给定集合元素存放在数组A[]中,正整数N是数组元素个数。该函数须返回NA[]元素的中位数,其值也必须是ElementType类型。

裁判测试程序样例:

#include 
#define MAXN 10typedef float ElementType;ElementType Median( ElementType A[], int N );int main (){ ElementType A[MAXN]; int N, i; scanf("%d", &N); for ( i=0; i

输入样例:

312.3 34 -5

输出样例:

12.30

 

学习了一下希尔排序,原地算法之一,每一次二分步长,将步长内可到达的每一个数都视为同一组,再对每一组进行直接插入排序,以前一直以为是两两之间排序,样例都过不了……

代码:

ElementType Median( ElementType A[], int N ){    int i,j,gap;    for (gap=N>>1; gap; gap>>=1)    {        for (i=gap; i
=0&&A[j]>A[j+gap]; j-=gap) { ElementType temp=A[j]; A[j]=A[j+gap]; A[j+gap]=temp; } } } return A[N>>1];}

转载于:https://www.cnblogs.com/Blackops/p/5863630.html

你可能感兴趣的文章
0302 关于IT行业的就业感想
查看>>
3、流程语句相关练习
查看>>
30、git 使用
查看>>
iOS网络-02-数据解析(JSON与XML)
查看>>
python列表求和的几种等效电路
查看>>
Luogu P3393 逃离僵尸岛
查看>>
Flatten Binary Tree to Linked List
查看>>
Edit Distance
查看>>
软件工程第一次作业补充
查看>>
N76E003---输入捕获
查看>>
poj 1094 Sorting It All Out(拓扑排序)
查看>>
acdream B - 郭式树 (水题 卡cin,cout, 卡LL)
查看>>
BMP图像格式
查看>>
python的匿名函数lambda解释及用法
查看>>
c#遍历Dictionary使用KeyValuePair
查看>>
defineProperties属性的运用==数据绑定
查看>>
关于 IOS 发布的点点滴滴记录(一)
查看>>
《EMCAScript6入门》读书笔记——14.Promise对象
查看>>
CSS——水平/垂直居中
查看>>
Eclipse连接mysql数据库jdbc下载(图文)
查看>>