当前位置: 首页 > news >正文

C语言及程序设计进阶例程-25 排序问题及其求解

贺老师教学链接 C语言及程序设计进阶 本课讲解

快速排序实现

#include<stdio.h>
void quicksort(int data[],int first,int last)
{
    int i, j, t, base;
    if (first>last)
        return;
    base=data[first];  /*用首元素作为基数*/
    i=first;
    j=last;
    while(i!=j)  /*重复下面的过程,直到i和j相遇*/
    {
        while(data[j]>=base && i<j)  /*j从右向左,找到小于基数的元素*/
            j--;
        while(data[i]<=base && i<j)  /*i从左向右,找到大于基数的元素*/
            i++;
        /*当i和j没有相遇有时候,交换两个数*/
        if(i<j)
        {
            t=data[i];
            data[i]=data[j];
            data[j]=t;
        }
    }
    data[first]=data[i];   /*将i,j相遇处的值保存在基数位置*/
    data[i]=base;   /*将基数保存在其应该的位置*/
    quicksort(data,first,i-1);   /*用同样的策略,递归处理左边的部分*/
    quicksort(data,i+1,last);    /*用同样的策略,递归处理右边的部分*/
}
int main( )
{
    int data[10] = {6, 1, 2, 7, 9, 3, 4, 5, 10, 8};
    quicksort(data, 0,9);
    int i;
    for(i=0; i<10; i++)
        printf("%d ", data[i]);
    printf("\n");
    return 0;
}

非比较类排序算法:简单计数排序

#include <stdio.h>
int main()
{
    int A[10] = {6,1,12,6,18,1,18,7,0,6}; /*通过初始化给出待排序值*/
    int C[21] = {0};  /*用于计数的C数组的所有元素初值为0*/
    int i, j;
    /*为每一个待排序的数计数*/
    for(i=0; i<10; i++)
        C[A[i]]++;    /*例如,A[i]为6时,C[6]++,C[i]是i出现的次数*/
    /*根据计数信息输出*/
    for(i=0; i<21; i++)    /*考察待排序数据范围内的每一个数i*/
        for(j=1; j<=C[i]; j++)   /*输出C[i]个i,此即是排序的结果*/
            printf("%d ", i);
    printf("\n");
    return 0;
}

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • ThinkPhp学习09
  • TCP/IP详解学习笔记(6)-UDP协议
  • Kotlin:Android世界的Swift
  • js检测是否手机浏览的函数
  • 浅谈数据结构-二叉树
  • SharePoint 2013 开发——APP开发的考虑和建议
  • LAMP环境搭建
  • 设置共享实验
  • 基线MRI与CRP是依那西普对nr-axSpA的疗效预测因素
  • 硬盘分区后丢失的文件怎么恢复
  • HEVC/H.265 的未来必须是使用并行处理(OpenCL?) OpenCV和OpenCL区别
  • C++ 与 CDC相关的知识,点滴总结
  • 一些误解和错误的看法
  • 从XML文件乱码问题,探寻其背后的原理(转)
  • Linux平台Java调用so库-JNI使用例子
  • ES6--对象的扩展
  • iOS 系统授权开发
  • iOS小技巧之UIImagePickerController实现头像选择
  • JDK9: 集成 Jshell 和 Maven 项目.
  • Leetcode 27 Remove Element
  • LeetCode29.两数相除 JavaScript
  • Netty源码解析1-Buffer
  • nodejs:开发并发布一个nodejs包
  • Service Worker
  • webpack入门学习手记(二)
  • 从setTimeout-setInterval看JS线程
  • 翻译:Hystrix - How To Use
  • 互联网大裁员:Java程序员失工作,焉知不能进ali?
  • 腾讯大梁:DevOps最后一棒,有效构建海量运营的持续反馈能力
  • 一加3T解锁OEM、刷入TWRP、第三方ROM以及ROOT
  • Java总结 - String - 这篇请使劲喷我
  • ​Redis 实现计数器和限速器的
  • #pragma 指令
  • $.ajax()
  • (附源码)springboot家庭装修管理系统 毕业设计 613205
  • (附源码)计算机毕业设计SSM在线影视购票系统
  • (理论篇)httpmoudle和httphandler一览
  • (六)Flink 窗口计算
  • (区间dp) (经典例题) 石子合并
  • (算法)大数的进制转换
  • (算法)硬币问题
  • (一)kafka实战——kafka源码编译启动
  • .MSSQLSERVER 导入导出 命令集--堪称经典,值得借鉴!
  • .net core 实现redis分片_基于 Redis 的分布式任务调度框架 earth-frost
  • .NET Core实战项目之CMS 第一章 入门篇-开篇及总体规划
  • .NET Framework 4.6.2改进了WPF和安全性
  • .NET(C#) Internals: as a developer, .net framework in my eyes
  • .NET/C# 的字符串暂存池
  • .net实现客户区延伸至至非客户区
  • .Net组件程序设计之线程、并发管理(一)
  • @AliasFor 使用
  • [ vulhub漏洞复现篇 ] Jetty WEB-INF 文件读取复现CVE-2021-34429
  • [ vulhub漏洞复现篇 ] ThinkPHP 5.0.23-Rce
  • [20171106]配置客户端连接注意.txt
  • [2019/05/17]解决springboot测试List接口时JSON传参异常