• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > 简单了解C语言中直接插入排序与直接选择排序实现

简单了解C语言中直接插入排序与直接选择排序实现

作者:lixiang0522 字体:[增加 减小] 来源:互联网 时间:2017-05-28

lixiang0522 通过本文主要向大家介绍了了解c语言,堆排序c语言实现,c语言实现冒泡排序,c语言实现快速排序,c语言实现排序等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

直接插入排序
基本思路:
1. 从a[0]开始,也就是从1个元素开始是有序的,a[1]~a[n-1]是无序的。
2. 从a[1]开始并入前面有序的数组,直到n-1。

#include <stdio.h> 
#define N 5 
 
void insertsort(int a[], int n); 
void swap(int *x, int *y); 
 
void insertsort(int a[], int n){ 
  int i,j; 
  for(i=1; i<n; i++){ 
    for(j=i; j>0 && a[j]<a[j-1]; j--){ 
      swap(&a[j], &a[j-1]); 
    }   
  } 
} 
 
void swap(int *x, int *y){ 
  int i = *x; 
  *x = *y; 
  *y = i; 
} 
 
int main(void){ 
  int a[N] = {2, 5, 3, 1, 8}; 
  insertsort(a, N); 
  int i; 
  for(i=0; i<N; i++) 
    printf("%d ", a[i]); 
  return 0; 
} 

</div>


直接选择排序

基本思路:
1. 从1开始通过对比找出最小的数的下标。然后把这个下标的值和0交换。
2. 循环把值交换到1 2 3 ... n-1。

#include <stdio.h> 
#define N 5 
 
void selectsort(int a[], int n); 
void swap(int *x, int *y); 
 
void selectsort(int a[], int n){ 
  int i,j; 
  for(i=0; i<n; i++){ 
    int min = i; 
    for(j=i+1; j<n; j++){ 
      if(a[j] < a[min]){ 
        min = j; 
      } 
    } 
    swap(&a[i], &a[min]); 
  } 
} 
 
void swap(int *x, int *y){ 
  int i = *x; 
  *x = *y; 
  *y = i; 
} 
 
int main(void){ 
  int a[N] = {2, 5, 3, 1, 8}; 
  selectsort(a, N); 
  int i; 
  for(i=0; i<N; i++) 
    printf("%d ", a[i]); 
  return 0; 
} 

</div>


</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 简单了解C语言中直接插入排序与直接选择排序实现

相关文章

  • 2017-05-28C++ clock()解析如何使用时钟计时的应用
  • 2017-05-28C语言顺序表实现代码排错
  • 2017-05-28深入解析C语言中typedef的四个用途
  • 2017-05-28解析取模运算% 和位与运算& 之间的关系详解
  • 2017-05-28基于C语言char与unsigned char的区别介绍
  • 2017-05-28C/C++ 多线程的学习心得总结
  • 2017-05-28简要对比C语言中的truncate()函数与ftruncate()函数
  • 2017-05-28C语言实现的猴子偷桃之类算法
  • 2017-05-28直观理解C语言中指向一位数组与二维数组的指针
  • 2017-05-28对比C语言中的setbuf()函数和setvbuf()函数的使用

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 学习C和C++的9点经验总结
    • C语言单循环链表的表示与实现实例详解
    • c语言多进程tcp服务器示例
    • 老生常谈C语言静态函数库的制作和使用
    • C语言 指针与数组的详解及区别
    • C语言中的strdup()函数和其与strcpy()函数的区别
    • C语言实现选择排序、冒泡排序和快速排序的代码示例
    • C++ 11和C++98相比有哪些新特性
    • C语言实现图的遍历之深度优先搜索实例
    • C语言实现基于最大堆和最小堆的堆排序算法示例

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有