7-19(排序) 寻找大富翁 (25 分)(归并排序)(C语言实现)
7-19(排序) 寻找大富翁 (25 分)
输入格式:
输出格式:
输入样例:
输出样例:
- #include<stdio.h>
- #include<stdlib.h>
- #define MAX_SIZE 1100000
- int a[MAX_SIZE]; //因为MAX_SIZE 太大,所以数组要定义在函数以外
- int temp[MAX_SIZE]; //中间数组,用完后赋值给原数组
- int merging(int* list1,int list1_size,int *list2,int list2_size)
- {
- int i=0,j=0,k=0;
- while(i<list1_size&&j<list2_size) //线性表的merge排序操作,merge的意思是融入
- {
- if(list1[i]<list2[j])
- {
- temp[k++]=list1[i++]; //注意不要漏掉里面的++
- }
- else
- {
- temp[k++]=list2[j++];
- }
- }
- while(i<list1_size)
- {
- temp[k++]=list1[i++];
- }
- while(j<list2_size)
- {
- temp[k++]=list2[j++];
- }
- for(i=0;i<list1_size+list2_size;i++) //赋值给原数组
- {
- list1[i]=temp[i];
- }
- return 0;
- }
- int MergeSort(int *a,int n)
- {
- if(n>1)
- {
- int *list1=a;
- int list1_size=n/2;
- int *list2=a+list1_size;
- int list2_size=n-list1_size;
- MergeSort(list1,list1_size); //递归左边的数组,对半分
- MergeSort(list2,list2_size); //递归右边的数组,对半分,因为对半分的,所以时间复杂度为log(n)
- merging(list1,list1_size,list2,list2_size); //合的操作,将左右有序的合为一个数组
- }
- return 0;
- }
- int main()
- {
- int n,m;
- scanf("%d%d",&n,&m);
- int i,flag=0;
- for(i=0;i<n;i++)
- {
- scanf("%d",&a[i]);
- }
- MergeSort(a,n);
- if(n>m) //---这里加一个判断,n与m不一定谁大,不然有一个点过不了
- {
- for(i=n-1;i>=n-m;i--)
- {
- if(flag==1)printf(" ");flag=1;
- printf("%d",a[i]);
- }
- }
- else
- {
- for(i=n-1;i>=0;i--)
- {
- if(flag==1)printf(" ");flag=1;
- printf("%d",a[i]);
- }
- }
- return 0;
- }
7-19(排序) 寻找大富翁 (25 分)(归并排序)(C语言实现)的更多相关文章
- PTA数据结构与算法题目集(中文) 7-38寻找大富翁 (25 分)
PTA数据结构与算法题目集(中文) 7-38寻找大富翁 (25 分) 7-38 寻找大富翁 (25 分) 胡润研究院的调查显示,截至2017年底,中国个人资产超过1亿元的高净值人群达15万人.假 ...
- 06-图1 列出连通集 (25分)(C语言邻接表实现)
题目地址:https://pta.patest.cn/pta/test/558/exam/4/question/9495 由于边数E<(n*(n-1))/2 所以我选用了邻接表实现,优先队列用循 ...
- 1010 一元多项式求导 (25 分) C语言
设计函数求一元多项式的导数.(注:xn(n为整数)的一阶导数为nxn−1.) 输入格式: 以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过 1000 的整数).数字间以空格分隔. ...
- SDUT 3401 数据结构实验之排序四:寻找大富翁.!
数据结构实验之排序四:寻找大富翁 Time Limit: 150MS Memory Limit: 512KB Submit Statistic Problem Description 2015胡润全球 ...
- PTA 09-排序1 排序 (25分)
题目地址 https://pta.patest.cn/pta/test/15/exam/4/question/720 5-12 排序 (25分) 给定NN个(长整型范围内的)整数,要求输出从小到大 ...
- hdoj 3785 寻找大富翁【优先队列+sort排序】
寻找大富翁 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
- SDUT OJ 数据结构实验之排序四:寻找大富翁
数据结构实验之排序四:寻找大富翁 Time Limit: 200 ms Memory Limit: 512 KiB Submit Statistic Discuss Problem Descripti ...
- PAT 甲级 1062 Talent and Virtue (25 分)(简单,结构体排序)
1062 Talent and Virtue (25 分) About 900 years ago, a Chinese philosopher Sima Guang wrote a histor ...
- PAT 甲级 1028 List Sorting (25 分)(排序,简单题)
1028 List Sorting (25 分) Excel can sort records according to any column. Now you are supposed to i ...
随机推荐
- Linux----虚拟机克隆、快照、删除、
克隆 已经安装一台linux系统 还想要更多的,直接克隆CentOS即可 使用vm ware 的克隆操作 注意: 使用前先关闭目前已开启的虚拟机 快照 作用: 虚拟系统出现异常,需要回到原先的状态,此 ...
- Java基础—字符串的比较
1."=="方法进行比较时有以下两种情况: 基础数据类型:比较的是数据值是否相同 引用类型:比较的是地址值是否相同 字符串是对象,它比较内容是通过一个方法实现的,equals() ...
- new和@Autowired的区别
controller层: @RequestMapping("/payment") @RestController public class WxPayController { pu ...
- Python之VSCode
在学习Python的过程中,一直没有找到比较趁手的第三方编辑器,用的最多的还是Python自带的编辑器.由于本人用惯了宇宙第一IDE(Visual Studio),所以当Visual Studio C ...
- linux的服务自动启动的配置
1.开机启动时自动运行程序 Linux加载后, 它将初始化硬件和设备驱动, 然后运行第一个进程init.init根据配置文件继续引导过程,启动其它进程.通常情况下,修改放置在 /etc/rc或 /et ...
- 从零开始,开发一个 Web Office 套件(13):删除、替换已选中文字
这是一个系列博客,最终目的是要做一个基于 HTML Canvas 的.类似于微软 Office 的 Web Office 套件(包括:文档.表格.幻灯片--等等). 博客园:<从零开始, 开发一 ...
- 编写 Shell 程序,实现自动删除 50 个账号的功能,账号名为stud1 至 stud50 ?
#!/bin/bashfor((i=1;i<51;i++))do userdel -r stud$idone
- struts2学习二:Tomcat的部署目录和访问路径问题
1:idea中配置tomcat后,那么最终的web工程发布到哪里去了?为什么在访问路径中不加工程名就可以访问? 1.1:因为tomcat有段时间没接触了,先回顾下tomcat的目录结构吧? 如图所示: ...
- 阐述final、finally、finalize的区别?
- final:修饰符(关键字)有三种用法:如果一个类被声明为final,意味着它不能再派生出新的子类,即不能被继承,因此它和abstract是反义词.将变量声明为final,可以保证它们在使用中不被 ...
- C++多态例子_虚函数
#include<iostream> using namespace std; class parent { public: virtual void fun() { cout <& ...