不得不说,手写的快排真的好菜。(即使开了随机数...)


快速排序

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
using namespace std;
inline int read();
 ;
namespace iNx{
    int n;
    int q[Maxn];
    void exchange(int a,int b){
        int t=q[a];
        q[a]=q[b];
        q[b]=t;
    }
    void quicksort(int left,int right){
        if(left>=right) return ;
        exchange(left,(rand()%(right-left+))+left);
        int key=q[left],i=left,j=right;
        while(i<j){
            while(q[j]>=key&&i<j) j--;
            if(j>i) q[i++]=q[j];
            while(q[i]<=key&&i<j) i++;
            if(i<j) q[j--]=q[i];
        }
        q[i]=key;
        quicksort(left,i-);
        quicksort(i+,right);
    }
    int main(){
        n=read();
        int i;
        ;i<=n;i++) q[i]=read();
        quicksort(,n);
        ;i<=n;i++) printf("%d ",q[i]);
        puts("");
        ;
    }
}
int main(){
    iNx::main();
    ;
}
inline int read(){
    ,ff=;
    char c=getchar();
    '){
        ;
        c=getchar();
    }
    +c-',c=getchar();
    return kk*ff;
}

归并排序

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
inline int read();

 ;
namespace iNx{
    int n,q[Maxn],t[Maxn];
    void mergesort(int left,int right){
        if(left>=right) return ;
        ;
        mergesort(left,mid);
        mergesort(mid+,right);
        ,k=left;
        while(i<=mid&&j<=right){
            if(q[i]<=q[j]) t[k++]=q[i++];
            else t[k++]=q[j++];
        }
        while(i<=mid) t[k++]=q[i++];
        while(j<=right) t[k++]=q[j++];
        for(i=left;i<=right;i++) q[i]=t[i];
    }
    int main(){
        n=read();
        int i;
        ;i<=n;i++) q[i]=read();
        mergesort(,n);
        ;i<=n;i++) printf("%d ",q[i]);
        puts("");
    }
}
int main(){
    iNx::main();
    ;
}
inline int read(){
    ,ff=;
    char c=getchar();
    '){
        ;
        c=getchar();
    }
    +c-',c=getchar();
    return kk*ff;
}

可以到洛谷上测试:P1177 【模板】快速排序

附上两种代码测评结果(此题时间限制3s):

快速排序:

归并排序:

(天天进步一点点hhh。)

[模板][快速排序&归并排序]的更多相关文章

  1. Luogu 1177 - 【模板】快速排序 - [快速排序][归并排序][无旋Treap]

    题目链接:https://www.luogu.org/problemnew/show/P1177 题意:输入 $n$ 以及后续 $n$ 个整数,让你将这 $n$ 个整数从小到大排序输出. 归并排序(用 ...

  2. 快速排序&&归并排序

    快速排序 快速排序采用的是分治的策略,算法的具体实现过程是 1.确定一个数X(一般是选中间值X=q[l+r>>1]) 2.利用指针i,j,将数组中比X小的数放在一边,比X大的数放在另一边 ...

  3. c语言 快速排序---归并排序----堆排序

    //快速排序: #include <stdio.h> #define MAX 500000 int s[MAX]; void Q_Sort(int start,int end) { int ...

  4. noi.ac #32 快速排序归并排序应用

    \(des\) 给定长度为 \(n\) 的数组,要求翻转一段区间 \([l, r]\) 使其升序排列. 要求 \(\sum r - l + 1 <= 2e7\) \(sol\) 考虑快速排序,每 ...

  5. 9, java数据结构和算法: 直接插入排序, 希尔排序, 简单选择排序, 堆排序, 冒泡排序,快速排序, 归并排序, 基数排序的分析和代码实现

    内部排序: 就是使用内存空间来排序 外部排序: 就是数据量很大,需要借助外部存储(文件)来排序. 直接上代码: package com.lvcai; public class Sort { publi ...

  6. 洛谷【P1177】【模板】归并排序

    题目传送门:https://www.luogu.org/problemnew/show/P1177 归并排序: 1.先将\(a\)数组的区间\([l,mid],[mid+1,r]\)排成有序的. 2. ...

  7. 快速排序 O(n logn) 堆排序 O(n logn) 归并排序 O(n logn)

    NB三人组 快速排序 思路" 取一个元素P (第一个元素), 使元素归位 列表被P 分成两部分,左边都比P小,右边比P大; 递归完成排序. 问题 如果是已经排序好的 倒叙 列表 则会 递归深 ...

  8. 快速排序 Vs. 归并排序 Vs. 堆排序——谁才是最强的排序算法

    知乎上有一个问题是这样的: 堆排序是渐进最优的比较排序算法,达到了O(nlgn)这一下界,而快排有一定的可能性会产生最坏划分,时间复杂度可能为O(n^2),那为什么快排在实际使用中通常优于堆排序? 昨 ...

  9. 归并排序 & 计数排序 & 基数排序 & 冒泡排序 & 选择排序 ----> 内部排序性能比较

    2.3 归并排序 接口定义: int merge(void* data, int esize, int lpos, int dpos, int rpos, int (*compare)(const v ...

随机推荐

  1. discuz 设置

    veikei_dz_com_20120821_gray_free 模板  论坛 瀑布流 需要在后台设置  论坛--板块管理--编辑对应板块--扩展设置--开启图片列表模式 FAQ 帮助页面 在后台管理 ...

  2. Linux文件目录的权限

    权限对文件的重要性:(主要是针对文件的内容而言,与文件名没有关系) r: 可读取此文件的实际内容. w: 可以编辑.新增或者修改该文件的内容(但不能删除该文件) x: 该文件具有可以被系统执行的权限. ...

  3. python 并发编程 多线程 Thread对象的其他属性或方法

    介绍 Thread实例对象的方法 # isAlive(): 返回线程是否活动的. # getName(): 返回线程名. # setName(): 设置线程名. threading模块提供的一些方法: ...

  4. Linux上面执行 Windows 命令(比如 重启服务)的简单方法

    1. 首先 基础是:openssh 还有 expect的包 2. 方法 安装openssh 转帖来自: https://www.jianshu.com/p/6e5bc39d386e 最近项目在搞Jen ...

  5. java学习笔记 - 线程池(一)

    线程池(Thread Pool):把一个或多个线程通过统一的方式进行调度和重复使用的技术,避免了因为线程过多而带来使用上的开销 优点:(面试题)可重复使用已有线程,避免对象创建.消亡和过度切换的性能开 ...

  6. POJ 2253 Frogger(dijkstra 最短路

    POJ 2253 Frogger Freddy Frog is sitting on a stone in the middle of a lake. Suddenly he notices Fion ...

  7. 三校联训 【NOIP模拟】寻找

    题面 “我有个愿望,我希望穿越一切找到你.” 这是个二维平面世界,平面上有n个特殊的果实,我从(0,0)点出发,希望得到尽量多的果实,但是出于某种特殊的原因,我的运动方式只有三种(假设当前我在(x,y ...

  8. linux:用户和组文件解释(/etc/passwd、/etc/shadow、/etc/group、/etc/gshadow)

    一.用户文件:/etc/passwd [root@pinfun6 ~]# cat /etc/passwd root:x:0:0:root:/root:/bin/bash 1 2 3 4 5 6 7 | ...

  9. Balloon Robot ZOJ - 3981

    大意: n个参赛队, m个座位, 一共交了p次题, 一个机器人每秒钟会从位置$i$走到$i+1$, 若在$m$直接走到$1$, 当走到一个队伍就给该队应得的气球. 对于每道题, 假设交题时间$t_a$ ...

  10. sql server 平方根函数SQRT(x)

    --SQRT(x)返回非负数x的二次方根 示例:select  SQRT(9), SQRT(36); 结果:3    6