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 ...
随机推荐
- 做一个能对标阿里云的前端APM工具(上)
APM 全称是 Application Performance Monitor,即性能监控 这篇文章有三个前提: 从产品形态上看这肯定不是一个能够媲美阿里产品的竞品,所以抱歉我碰瓷了.你可以把这里的阿 ...
- SpringBoot 中实现跨域的几种方式
一.为什么会出现跨域问题 出于浏览器的同源策略限制.同源策略(Sameoriginpolicy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,则浏览器的正常功能可能都会受到影响. ...
- python psutila模块
#!/usr/bin/env python #coding:utf-8 # qianxiao996精心制作 #博客地址:https://blog.csdn.net/qq_36374896 import ...
- Python 局域网主机存活扫描
#! python # -*- coding: utf-8 -*- __author__ = 'Deen' import os import threading import argparse # 从 ...
- MySQL&SQL server&Oracle&Access&PostgreSQL数据库sql注入详解
判断数据库的类型 当我们通过一些测试,发现存在SQL注入之后,首先要做的就是判断数据库的类型. 常用的数据库有MySQL.Access.SQLServer.Oracle.PostgreSQL.虽然绝大 ...
- 数据库篇:mysql锁详解
前言 sql事务的执行,如果需要锁定数据进行更新操作,则必定离不开锁 共享锁和排他锁 表锁 行锁 Record Lock 间隙锁 Gap Lock 行锁+间隙锁 Next-Key Lock 加锁场景( ...
- Java并发机制(5)--同步容器与并发容器
Java并发编程:同步容器整理自:博客园-海子-http://www.cnblogs.com/dolphin0520/p/3933404.html1.同步容器出现原因 常用的ArrayList,Lin ...
- 为什么 wait(), notify()和 notifyAll ()必须在同步方法或 者同步块中被调用?
当一个线程需要调用对象的 wait()方法的时候,这个线程必须拥有该对象的锁,接 着它就会释放这个对象锁并进入等待状态直到其他线程调用这个对象上的 notify() 方法.同样的,当一个线程需要调用对 ...
- 简述 Mybatis 的插件运行原理,以及如何编写一个插件。
Mybatis 仅可以编写针对 ParameterHandler.ResultSetHandler. StatementHandler.Executor 这 4 种接口的插件,Mybatis 使用 J ...
- springboot-访问数据库
在springboot中,默认的JPA实现是Hibernate,JPA是Java Persistence API的简称,中文名Java持久层API <!--数据库--> <depen ...