c语言quicksort排序代码的简单介绍

本文目录一览:

C语言快速排序的代码

首先我赞成你直接要代码的这种方法。

从你这个提问可以看出你对常用的排序算法都接触过,并且都没搞懂到底是怎么回事。

现在的电子平台资源都很丰富了,硬件平台的运行速度可以做到很高了,在大多数的情况下可以考虑用空间换时间的方法,也就是说你应该先搞懂算法的本质,然后再自己去实现它,开始的时候可以不考虑时间上的损耗。

排序的本质就是两个数比较大小,并根据其大小将其放到相应的位置。

记住其本质是什么,你自己绝对可以使用相应的语言实现它。

用c语言编写函数QuickSort()来实现快速排序

#include stdlib.h

#include stdio.h

#define MAXN 8

#define MOD 1024

void QuickSort(int *arr, int low, int high)

{

    if (low = high) return;

    //保存排序区间的 起始位置和终点位置

    int left = low, right = high;

    //默认 左边第一个元素 为标志

    int key = arr[low];

    while (low  high)

    {

        while (low  high  arr[high] = key) –high;

        arr[low] = arr[high];

        while (low  high  arr[low] = key) ++low;

        arr[high] = arr[low];

    }

    arr[low] = key;

    //每次排序后都分成两部分[left, low) (low, right]

    //arr[low]的位置是一定是有序的

    QuickSort(arr, left, low – 1);

    QuickSort(arr, low + 1, right);

    return;

}

int main(void)

{

    int n;

    scanf(“%d”, n);

    int arr[MAXN] = {0};

    int i;

    for (i = 0; i  n; ++i)

        scanf(“%d”, arr[i]);

    //输入是默认为生活中习惯的数组左边第一个为:编号1

    int s, m;

    scanf(“%d %d”, s, m);

    //转成计算机数组第一个为:编号0

    s–; m–;

    //快排

    QuickSort(arr, s, m);

    //输出

    for (i = s; i = m; ++i)

    {

        printf(“%d “, arr[i]);

    }

    return 0;

}

//测试数据

//8

//1 2 3 4 5 6 7 8

//2 6

输出 6 5 4 3 2

用C语言编程实现快速排序算法

给个快速排序你参考参考

/********************** 快速排序 ****************************

基本思想:在待排序的n个记录中任取一个记录(通常取第一个记录),

  以该记录为基准,将当前的无序区划分为左右两个较小的无

  序子区,使左边的记录均小于基准值,右边的记录均大于或

  等于基准值,基准值位于两个无序区的中间位置(即该记录

  最终的排序位置)。之后,分别对两个无序区进行上述的划

  分过程,直到无序区所有记录都排序完毕。

*************************************************************/

/*************************************************************

函数名称:static void swap(int *a, int *b)

参    数:int *a—整型指针

  int *b—整型指针

功    能:交换两个整数的位置

返 回 值:无

说    明:static关键字指明了该函数只能在本文件中使用

**************************************************************/

static void swap(int *a, int *b)

{  

    int temp = *a;

    *a = *b;

    *b = temp;

}

int quickSortNum = 0; // 快速排序算法所需的趟数

/*************************************************************

函数名称:static int partition(int a[], int low, int high)

参    数:int a[]—待排序的数据

  int low—无序区的下限值

  int high—无序区的上限值

功    能:完成一趟快速排序

返 回 值:基准值的最终排序位置

说    明:static关键字指明了该函数只能在本文件中使用

**************************************************************/

static int partition(int a[], int low, int high)

{

    int privotKey = a[low];  //基准元素

    while(low  high)

{   //从表的两端交替地向中间扫描  

        while(low  high   a[high] = privotKey)   // 找到第一个小于privotKey的值

high–;  //从high所指位置向前搜索,至多到low+1位置  

        swap(a[low], a[high]);  // 将比基准元素小的交换到低端

        while(low  high   a[low] = privotKey)   // 找到第一个大于privotKey的值

low++;  //从low所指位置向后搜索,至多到high-1位置

        swap(a[low], a[high]);  // 将比基准元素大的交换到高端

    }

quickSortNum++;  // 快速排序趟数加1

return low;  // 返回基准值所在的位置

}  

/*************************************************************

函数名称:void QuickSort(int a[], int low, int high)

参    数:int a[]—待排序的数据

  int low—无序区的下限值

  int high—无序区的上限值

功    能:完成快速排序算法,并将排序完成的数据存放在数组a中

返 回 值:无

说    明:使用递归方式完成

**************************************************************/

void QuickSort(int a[], int low, int high)

{  

    if(low  high)

{

        int privotLoc = partition(a, low, high); // 将表一分为二  

        QuickSort(a, low, privotLoc-1);          // 递归对低子表递归排序  

        QuickSort(a, privotLoc+1, high);         // 递归对高子表递归排序  

    }

}

C语言快速排序代码

采用快速排序,用递归实现

#include stdio.h

#define N 10 //定义排序数组元素个数

int Qsort(int start,int length,int a[])//start排序的起始,length是要排序序列长度

{

int x = a;

int i,j;

i = start;

j = length -1;

while(i j)

{

if(x a[j])

j–;

else if(x a[j])

{

a[i] = a[j];

a[j] = x;

i++;

}

else if(x a[i])

{

a[j] = a[i];

a[i] = x;

j–;

}

else

i++;

}

if(start length-1)

{

Qsort(start,i,a);

Qsort(i+1,length,a);

}

}

void main()

{

int a[N] = {0};

int i;

for(i = 0;i N;i++)

scanf(“%d”,a[i]);

Qsort(0,N,a);

for(i = 0;i N;i++)

printf(“%d “,a[i]);

}

程序执行时输入N个数,对这N个数进行排序,可以预设N的长度

原创文章,作者:HMYV,如若转载,请注明出处:https://www.506064.com/n/136892.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
HMYVHMYV
上一篇 2024-10-04 00:16
下一篇 2024-10-04 00:16

相关推荐

  • Python周杰伦代码用法介绍

    本文将从多个方面对Python周杰伦代码进行详细的阐述。 一、代码介绍 from urllib.request import urlopen from bs4 import Bea…

    编程 2025-04-29
  • Python字符串宽度不限制怎么打代码

    本文将为大家详细介绍Python字符串宽度不限制时如何打代码的几个方面。 一、保持代码风格的统一 在Python字符串宽度不限制的情况下,我们可以写出很长很长的一行代码。但是,为了…

    编程 2025-04-29
  • Python基础代码用法介绍

    本文将从多个方面对Python基础代码进行解析和详细阐述,力求让读者深刻理解Python基础代码。通过本文的学习,相信大家对Python的学习和应用会更加轻松和高效。 一、变量和数…

    编程 2025-04-29
  • Python简单数学计算

    本文将从多个方面介绍Python的简单数学计算,包括基础运算符、函数、库以及实际应用场景。 一、基础运算符 Python提供了基础的算术运算符,包括加(+)、减(-)、乘(*)、除…

    编程 2025-04-29
  • AES加密解密算法的C语言实现

    AES(Advanced Encryption Standard)是一种对称加密算法,可用于对数据进行加密和解密。在本篇文章中,我们将介绍C语言中如何实现AES算法,并对实现过程进…

    编程 2025-04-29
  • 学习Python对学习C语言有帮助吗?

    Python和C语言是两种非常受欢迎的编程语言,在程序开发中都扮演着非常重要的角色。那么,学习Python对学习C语言有帮助吗?答案是肯定的。在本文中,我们将从多个角度探讨Pyth…

    编程 2025-04-29
  • 仓库管理系统代码设计Python

    这篇文章将详细探讨如何设计一个基于Python的仓库管理系统。 一、基本需求 在着手设计之前,我们首先需要确定仓库管理系统的基本需求。 我们可以将需求分为以下几个方面: 1、库存管…

    编程 2025-04-29
  • Python满天星代码:让编程变得更加简单

    本文将从多个方面详细阐述Python满天星代码,为大家介绍它的优点以及如何在编程中使用。无论是刚刚接触编程还是资深程序员,都能从中获得一定的收获。 一、简介 Python满天星代码…

    编程 2025-04-29
  • 写代码新手教程

    本文将从语言选择、学习方法、编码规范以及常见问题解答等多个方面,为编程新手提供实用、简明的教程。 一、语言选择 作为编程新手,选择一门编程语言是很关键的一步。以下是几个有代表性的编…

    编程 2025-04-29
  • Python实现简易心形代码

    在这个文章中,我们将会介绍如何用Python语言编写一个非常简单的代码来生成一个心形图案。我们将会从安装Python开始介绍,逐步深入了解如何实现这一任务。 一、安装Python …

    编程 2025-04-29

发表回复

登录后才能评论