题目地址

https://pta.patest.cn/pta/test/15/exam/4/question/720

5-12 排序   (25分)

给定NN个(长整型范围内的)整数,要求输出从小到大排序后的结果。

本题旨在测试各种不同的排序算法在各种数据情况下的表现。各组测试数据特点如下:

  • 数据1:只有1个元素;
  • 数据2:11个不相同的整数,测试基本正确性;
  • 数据3:103个随机整数;
  • 数据4:104个随机整数;
  • 数据5:105个随机整数;
  • 数据6:105个顺序整数;
  • 数据7:105个逆序整数;
  • 数据8:105个基本有序的整数;
  • 数据9:105个随机正整数,每个数字不超过1000。

    输入格式:

    输入第一行给出正整数NN(\le 10^5≤10​5​​),随后一行给出NN个(长整型范围内的)整数,其间以空格分隔。

    输出格式:

    在一行中输出从小到大排序后的结果,数字间以1个空格分隔,行末不得有多余空格。

    输入样例:

    11
    4 981 10 -17 0 -20 29 50 8 43 -5

    输出样例:

    -20 -17 -5 0 4 8 10 29 43 50 981

这个题是帮你计时用的。。

/*
给定NN个(长整型范围内的)整数,要求输出从小到大排序后的结果。 本题旨在测试各种不同的排序算法在各种数据情况下的表现。各组测试数据特点如下: 数据1:只有1个元素;
数据2:11个不相同的整数,测试基本正确性;
数据3:103个随机整数;
数据4:104个随机整数;
数据5:105个随机整数;
数据6:105个顺序整数;
数据7:105个逆序整数;
数据8:105个基本有序的整数;
数据9:105个随机正整数,每个数字不超过1000。 此题本身是用来比较排序算法速度用的,不过用快排综合水平挺快的。 写完算了 快排的结果
时间 结果 得分 题目 编译器 用时(ms) 内存(MB) 用户
2017-07-05 21:16 答案正确 25 5-12 gcc 52 2
测试点结果
测试点 结果 得分/满分 用时(ms) 内存(MB)
测试点1 答案正确 1/1 1 1
测试点2 答案正确 10/10 2 1
测试点3 答案正确 2/2 2 1
测试点4 答案正确 2/2 7 1
测试点5 答案正确 2/2 49 2
测试点6 答案正确 2/2 52 2
测试点7 答案正确 2/2 47 2
测试点8 答案正确 2/2 41 2
测试点9 答案正确 2/2 47 1 另,快排把cutoff从3改为100后,速度稍微快了一些
评测结果
时间 结果 得分 题目 编译器 用时(ms) 内存(MB) 用户
2017-07-05 21:20 答案正确 25 5-12 gcc 48 2
测试点结果
测试点 结果 得分/满分 用时(ms) 内存(MB)
测试点1 答案正确 1/1 2 1
测试点2 答案正确 10/10 2 1
测试点3 答案正确 2/2 2 1
测试点4 答案正确 2/2 8 1
测试点5 答案正确 2/2 48 2
测试点6 答案正确 2/2 39 2
测试点7 答案正确 2/2 41 2
测试点8 答案正确 2/2 42 2
测试点9 答案正确 2/2 44 1 插排的结果
评测结果
时间 结果 得分 题目 编译器 用时(ms) 内存(MB) 用户
2017-07-05 21:19 答案正确 25 5-12 gcc 7915 2
测试点结果
测试点 结果 得分/满分 用时(ms) 内存(MB)
测试点1 答案正确 1/1 2 1
测试点2 答案正确 10/10 2 1
测试点3 答案正确 2/2 2 1
测试点4 答案正确 2/2 26 1
测试点5 答案正确 2/2 3495 2
测试点6 答案正确 2/2 40 2
测试点7 答案正确 2/2 7915 2
测试点8 答案正确 2/2 63 2
测试点9 答案正确 2/2 3587 1
*/ #include<stdio.h>
#define CUTOFF 100
int T[100000];
void swap(int *a,int *b)
{
int temp;
temp=*a;
*a=*b;
*b=temp;
} int median3(int a[],int left,int right)
{
// printf("median3 got %d as left,%d as right\n",left,right);
int middle=(left+right)/2;
if(a[left]>a[right])
swap(&a[left],&a[right]);
if(a[left]>a[middle])
swap(&a[left],&a[middle]);
if(a[middle]>a[right])
swap(&a[middle],&a[right]); swap(&a[middle],&a[right-1]);
// printf("median3 got %d as a pivot,middle=%d\n",a[right-1],middle);
return a[right-1];
} void InsertionSort(int a[],int left ,int right)
{
int i,j,temp;
for(i=left;i<right;i++)
{
temp=a[i+1];
for(j=i+1;j>left;j--)
{
if(temp<a[j-1])
a[j]=a[j-1];
else break;
}
a[j]=temp;
}
}
void quicksort(int a[],int left,int right)
{
int low,high,pivot;
low=left;
high=right-1;
if(right-left<=CUTOFF)
{
InsertionSort(a,left,right);
return;
} pivot=median3(a,left,right);
while(1)
{
while(a[++low]<pivot);
while(a[--high]>pivot);
if(low<high)
swap(&a[low],&a[high]);
else break;
}
swap(&a[low],&a[right-1]);
quicksort(a,left,low-1);
quicksort(a,low+1,right);
} int main()
{
int i,N;
scanf("%d",&N);
for(i=0;i<N;i++)
{
scanf("%d",&T[i]);
}
quicksort(T,0,N-1); for(i=0;i<N;i++)
{
printf("%d",T[i]);
if(i!=N-1)
printf(" ");
}
}

  

PTA 09-排序1 排序 (25分)的更多相关文章

  1. PTA 7-3 Windows消息队列 (25分)

    PTA 7-3 Windows消息队列 (25分) 消息队列是Windows系统的基础.对于每个进程,系统维护一个消息队列.如果在进程中有特定事件发生,如点击鼠标.文字改变等,系统将把这个消息加到队列 ...

  2. PTA 7-3 树的遍历 (25分)

    PTA 7-3 树的遍历 (25分) 给定一棵二叉树的后序遍历和中序遍历,请你输出其层序遍历的序列.这里假设键值都是互不相等的正整数. 输入格式: 输入第一行给出一个正整数N(≤30),是二叉树中结点 ...

  3. PTA 是否二叉搜索树 (25分)

    PTA 是否二叉搜索树 (25分) 本题要求实现函数,判断给定二叉树是否二叉搜索树. 函数接口定义: bool IsBST ( BinTree T ); 其中BinTree结构定义如下: typede ...

  4. PTA 哈利·波特的考试 (25分)

    PTA 哈利·波特的考试 (25分) 哈利·波特要考试了,他需要你的帮助.这门课学的是用魔咒将一种动物变成另一种动物的本事.例如将猫变成老鼠的魔咒是haha,将老鼠变成鱼的魔咒是hehe等等.反方向变 ...

  5. PTA 11-散列2 Hashing (25分)

    题目地址 https://pta.patest.cn/pta/test/16/exam/4/question/679 5-17 Hashing   (25分) The task of this pro ...

  6. PTA 03-树3 Tree Traversals Again (25分)

    题目地址 https://pta.patest.cn/pta/test/16/exam/4/question/667 5-5 Tree Traversals Again   (25分) An inor ...

  7. PTA 03-树1 树的同构 (25分)

    题目地址 https://pta.patest.cn/pta/test/15/exam/4/question/711 5-3 树的同构   (25分) 给定两棵树T1和T2.如果T1可以通过若干次左右 ...

  8. PTA 7-2 列车调度(25 分)

    7-2 列车调度(25 分) 火车站的列车调度铁轨的结构如下图所示. 两端分别是一条入口(Entrance)轨道和一条出口(Exit)轨道,它们之间有N条平行的轨道.每趟列车从入口可以选择任意一条轨道 ...

  9. PTA PAT排名汇总(25 分)

    PAT排名汇总(25 分) 计算机程序设计能力考试(Programming Ability Test,简称PAT)旨在通过统一组织的在线考试及自动评测方法客观地评判考生的算法设计与程序设计实现能力,科 ...

  10. PTA 5-14 电话聊天狂人 (25分)

    给定大量手机用户通话记录,找出其中通话次数最多的聊天狂人. 输入格式: 输入首先给出正整数NN(\le 10^5≤10​5​​),为通话记录条数.随后NN行,每行给出一条通话记录.简单起见,这里只列出 ...

随机推荐

  1. as 开启代码混淆和混淆规则

    app的builde.gradle的文件下,buildTypes节点添加release节点,minifyEnabled属性表示是否开启混淆,proguardFiles表示混淆依赖的文件,具体开启方法如 ...

  2. Android程序中使用iconfont心得

    1.关于iconfont iconfont既是icon又是font,具体来说应该是用font形式展现的icon.与传统图片格式的图标不同,这一种图标因为是以字体形式展现的,所以更改大小.颜色.背景颜色 ...

  3. Azure Powershell blob中指定的vhd创建虚拟机

    #此脚本用于 Azure 存储账户中已有 vhd 镜像文件创建虚拟机,一般用于做好镜像测试 #----------------------------------------------------- ...

  4. 清理ThreadLocal

    在我很多的课程里(master.concurrency.xj-conc-j8),我经常提起ThreadLocal.它经常受到我严厉的指责要尽可能的避免使用.ThreadLocal是为了那些使用完就销毁 ...

  5. Java动态代理之InvocationHandler最简单的入门教程

    网上关于Java的动态代理,Proxy和InvocationHandler这些概念有讲解得非常高深的文章.其实这些概念没有那么复杂.现在咱们通过一个最简单的例子认识什么是InvocationHandl ...

  6. ABC3D创客项目:小风扇

    风扇是我们纳凉的好帮手,然而大多的风扇都体积庞大不易携带.利用电池进行供电能让风扇变得更加便捷,下面我们利用电池供电的原理制作出一个风扇. 工作原理: 这个OK风扇的主要能源来自于后面的7号电池,风扇 ...

  7. Swift REPL入门介绍

    Xcode 6.1 引入了一个新特性用来辅助Swift开发,即Read Eval Print Loop(“读取-求值-输出”循环,简称REPL).熟悉解释型语言的开发者将会对这个命令行环境感到舒适,而 ...

  8. Bootstrap历练实例:表单控件状态(禁用的字段集fieldset)

    禁用的字段集 fieldset 对 <fieldset> 添加 disabled 属性来禁用 <fieldset> 内的所有控件. <!DOCTYPE html>& ...

  9. iOS 高效 Mac 配置

    https://testerhome.com/topics/3045 https://support.apple.com/zh-cn/HT201236

  10. shell基础笔记1

    ---恢复内容开始--- 1 test命令中不能使用浮点小数值,如:    A=1.444444:[    $A -gt 1  ] 2 test命令中的>或<必须转义,否则shell会把它 ...