(c)函数指针做参数的冒泡排序

二叶草 2020年2月14日19:56:42函数代码评论阅读模式

冒泡排序算法相比大家都很熟悉了,但是这样的写法不知道大家试过没有,利用函数指针作为参数实现。

#include<stdio.h>

#include<time.h>

#include<stdlib.h>

void show_array(int a[], int n)

{

int i;

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

{

printf("%dn", a[i]);

}

putchar('n');

}

void init_array(int a[],int n)

{

int i;

srand(time(NULL));

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

{

a[i] = rand() % 100;

}

}

int cmp_int(void *a, void *b)

{

int x = *((int *)a);

int y = *((int *)b);

return x > y;

}

void swap_int(void *a, void *b)

{

int tmp;

tmp = *((int *)a);

*((int *)a) = *((int *)b);

*((int *)b) = tmp;

}

void bubble_sort(void *a, int n, int(*cmp)(void *, void *), void (*swap)(void *, void *))

{

int i, j;

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

{

for (j = 0; j < n - i - 1; j++)

{

if (cmp((void *)((int *)a+j), (void *)((int *)a+j + 1))>0)

swap((void *)((int *)a+j), (void *)((int *)a+j + 1));

}

}

}

int main(void)

{

int a[10];

init_array(a, 10);

show_array(a, 10);

bubble_sort(a, 10, cmp_int, swap_int);

show_array(a, 10);

getchar();

}

本文来源于:(c)函数指针做参数的冒泡排序-变化吧门户
特别声明:以上文章内容仅代表作者本人观点,不代表变化吧门户观点或立场。如有关于作品内容、版权或其它问题请于作品发表后的30日内与变化吧联系。

  • 赞助本站
  • 微信扫一扫
  • weinxin
  • 加入Q群
  • QQ扫一扫
  • weinxin
二叶草
Go语言中的常量 函数代码

Go语言中的常量

1 概述 常量,一经定义不可更改的量。功能角度看,当出现不需要被更改的数据时,应该使用常量进行存储,例如圆周率。从语法的角度看,使用常量可以保证数据,在整个运行期间内,不会被更改。例如当前处理器的架构...
Go语言的接口 函数代码

Go语言的接口

Go语言-接口 在Go语言中,一个接口类型总是代表着某一种类型(即所有实现它的类型)的行为。一个接口类型的声明通常会包含关键字type、类型名称、关键字interface以及由花括号包裹的若干方法声明...
Go语言支持的正则语法 函数代码

Go语言支持的正则语法

1 字符 语法 说明 . 任意字符,在单行模式(s标志)下,也可以匹配换行 字符类 否定字符类 d Perl 字符类 D 否定 Perl 字符类 ASCII 字符类 否定 ASCII 字符类 pN U...
Go语言的包管理 函数代码

Go语言的包管理

1 概述 Go 语言的源码复用建立在包(package)基础之上。包通过 package, import, GOPATH 操作完成。 2 main包 Go 语言的入口 main() 函数所在的包(pa...

发表评论