H面试程序(16): 简单选择排序
来源:互联网 发布:剑灵灵女捏脸数据图 编辑:程序博客网 时间:2024/06/10 14:50
#include<stdio.h>#include<assert.h>void display(int * a, int n) { assert(a);for(int i = 0; i < n; i++){printf("%d,",a[i]);}printf("\n");}void swap(int * a, int * b){ assert(a);assert(b);int temp;temp = *a;*a = *b;*b = temp;}void select_sort(int * a, int n){ assert(a);int i, j,min;for( i = 0; i < n-1 ; i++) //i 0 ~ n-2{min = a[i]; //每次选择一个作为最小值for( j = i; j < n; j++) // j i ~ n-1{if(a[j] < min){ swap(&(a[j]), &(a[i])); }}}}int main(){ int a[10] ={2, 1, 3, 4, 5, 7,2,3, 6, 1};int num = sizeof(a)/sizeof(int);printf("before_sort:");display(a, num);select_sort(a,num);printf("after_sort:");display(a, num);return 0;}
#include <stdio.h>#include <time.h>//交换两个数据void swap(int *a, int *b){int temp;temp = *a;*a = *b;*b = temp;}//显示交换后的数组void display_array( int a[], int n ){ int i; for( i = 0; i < n; i++ ) printf( "%d ", a[i] );}//选择排序void select_sort( int a[], int n ){int i ,j;for(i = 0; i<n-1 ; i++ ) { int min = a[i]; //每次都设定最小的数,i 0 ~ 8for(j =i+1; j <n; j++) // 将a[i]~ a[9]的数于当前最小的数进行比较,如果小于当前最小数就交换{if(a[j] < min){swap(&(a[j]), &(a[i]));}}}}int main(){clock_t start, finish;start = clock(); int n = 10; int a[] = { 2, 1, 3, 4, 5, 7, 6, 8 ,2,4}; printf( "Before sorting: " ); display_array( a, n ); select_sort( a, n ); printf( "After sorting: " ); display_array( a, n ); finish = clock(); printf("\n本次计算一共耗时: %f秒\n\n", (double)(finish-start)/CLOCKS_PER_SEC); return 0;}
- H面试程序(16): 简单选择排序
- H面试程序(17): 堆排序
- H面试程序(18): 归并排序
- H面试程序(14): 快速排序法
- H面试程序(15): 冒泡排序法
- 简单排序(选择排序)
- C语言程序----排序(直接插入排序,SHELL排序,冒泡排序,快速排序,简单选择排序,堆排序)
- H面试(20): 排序总结
- 简单排序算法:简单选择排序(选择排序)
- 简单排序(简单选择排序)
- H面试程序(2)josephus 问题
- H面试程序(27):字串转换
- 《面试》 几种经典的简单的排序方法(冒泡,选择,插入)python实现
- 排序7:选择排序(简单选择排序)
- 选择排序(简单选择排序 and 堆排序)
- 数组选择(简单)排序
- (1)简单选择排序
- 简单选择排序(js)
- java图标设置
- JobTracker健康监控测试作业
- 根据先序中序求后序的递归算法
- ios屏幕尺寸
- Eclipse统计工程源码行数
- H面试程序(16): 简单选择排序
- SHARED POOL的优化思路
- RabbitMQ---辟蹊径构建RabbitMQ集群
- Char类型与Varchar类型的区别
- sdasd
- 我爱csdn
- IOS在开启ARC的时候忽略某些类中的手写垃圾回收用到的方法
- 模拟时钟Message和Handler的简易应用
- useradd和adduser