c语言的函数怎么排序 c语言调用函数排序数字

C语言sort函数如何使用C语言中没有预置的sort函数 。如果在C语言中,遇到有调用sort函数,就是自定义的一个函数 , 功能一般用于排序 。
一、可以编写自己的sort函数 。
如下函数为将整型数组从小到大排序 。
void sort(int *a, int l)//a为数组地址 , l为数组长度 。
{
int i, j;
int v;
//排序主体
for(i = 0; il - 1; i)
for(j = i 1; jl; j)
{
if(a[i]a[j])//如前面的比后面的大 , 则交换 。
{
v = a[i];
a[i] = a[j];
a[j] = v;
}
}}
对于这样的自定义sort函数,可以按照定义的规范来调用 。
二、C语言有自有的qsort函数 。
功 能: 使用快速排序例程进行排序
头文件:stdlib.h
原型: void qsort(void *base,int nelem,int width,int (*fcmp)(const void *,const void *));
参数:
1 待排序数组首地址
2 数组中待排序元素数量
3 各元素的占用空间大小
4 指向函数的指针,用于确定排序的顺序
这个函数必须要自己写比较函数,即使要排序的元素是int,float一类的C语言基础类型 。
以下是qsort的一个例子:
#includestdio.h
#includestdlib.h
int comp(const void*a,const void*b)//用来做比较的函数 。
{
return *(int*)a-*(int*)b;
}
int main()
{
int a[10] = {2,4,1,5,5,3,7,4,1,5};//乱序的数组 。
int i;
qsort(a,n,sizeof(int),comp);//调用qsort排序
for(i=0;i10;i)//输出排序后的数组
{
printf("%d\t",array[i]);
}
return 0;
}
扩展资料:
sort函数的用法(C排序库函数的调用)
对数组进行排序 , 在c中有库函数帮我们实现,这们就不需要我们自己来编程进行排序了 。
(一)为什么要用c标准库里的排序函数
Sort()函数是c一种排序方法之一,学会了这种方法也打消我学习c以来使用的冒泡排序和选择排序所带来的执行效率不高的问题!因为它使用的排序方法是类似于快排的方法,时间复杂度为n*log2(n),执行效率较高!
(二)c标准库里的排序函数的使用方法
I)Sort函数包含在头文件为#includealgorithm的c标准库中,调用标准库里的排序方法可以不必知道其内部是如何实现的 , 只要出现我们想要的结果即可!
II)Sort函数有三个参数:
(1)第一个是要排序的数组的起始地址 。
(2)第二个是结束的地址(最后一位要排序的地址的下一地址)
(3)第三个参数是排序的方法,可以是从大到小也可是从小到大,还可以不写第三个参数,此时默认的排序方法是从小到大排序 。
Sort函数使用模板:
Sort(start,end,排序方法)
下面就具体使用sort()函数结合对数组里的十个数进行排序做一个说明!
例一:sort函数没有第三个参数,实现的是从小到大
#includeiostream
#includealgorithm
using namespace std;
int main()
{
int a[10]={9,6,3,8,5,2,7,4,1,0};
for(int i=0;i10;i)
couta[i]endl;
sort(a,a 11);
for(int i=0;i10;i)
couta[i]endl;
return 0;
}
编译器
GCC,GNU组织开发的开源免费的编译器
MinGW,Windows操作系统下的GCC
Clang,开源的BSD协议的基于LLVM的编译器
Visual C:: cl.exe , Microsoft VC自带的编译器
集成开发环境
CodeBlocks , 开源免费的C/CIDE
CodeLite,开源、跨平台的C/C集成开发环境
Orwell Dev-C,可移植的C/CIDE
C-Free
Light Table
Visual Studio系列
Hello World
参考资料:百度百科-sort函数
c语言的两种排序?1、选择排序法
要求输入10个整数c语言的函数怎么排序,从大到小排序输出
输入:2 0 3 -4 8 9 5 1 7 6
输出:9 8 7 6 5 3 2 1 0 -4
代码:
#includelt;stdio.hgt;
int main(int argc,const char*argv[]){
int num[10],i,j,k,l,temp;
//用一个数组保存输入的数据
for(i=0;ilt;=9;i)
{
scanf("%d",numlt;igt;);
}
//用两个for嵌套循环来进行数据大小比较进行排序
for(j=0;jlt;9;j)
{
for(k=j 1;klt;=9;k)
{
if(num[j]lt;num[k])//num[j]lt;num[k]
{
temp=num[j];
num[j]=num[k];
num[k]=temp;
}
}
}
//用一个for循环来输出数组中排序好的数据
for(l=0;llt;=9;l)
{
printf("%d",num[l]);
}
return 0;
}
2、冒泡排序法
要求输入10个整数c语言的函数怎么排序 , 从大到小排序输出
输入:2 0 3-4 8 9 5 1 7 6
输出:9 8 7 6 5 3 2 1 0-4
代码:
#includelt;stdio.hgt;
int main(int argc,const char*argv[]){
//用一个数组来存数据
int num[10],i,j,k,l,temp;
//用for来把数据一个一个读取进来
for(i=0;ilt;=9;i)
{
【c语言的函数怎么排序 c语言调用函数排序数字】scanf("%d",numlt;igt;);
}
//用两次层for循环来比较数据,进行冒泡
for(j=0;jlt;9;j)
{
for(k=0;klt;9-j;k)
{
if(num[k]lt;num[k 1])//num[k]lt;num[k 1]
{
temp=num[k];
num[k]=num[k 1];
num[k 1]=temp;
}
}
}
//用一个for循环来输出数组中排序好的数据
for(l=0;llt;=9;l)
{
printf("%d",num[l]);
}
return 0;
}
扩展资料:
return 0代表程序正常退出 。return是C预定义的语句,它提供了终止函数执行的一种方式 。当return语句提供了一个值时,这个值就成为函数的返回值 。
return语句用来结束循环,或返回一个函数的值 。
1、return 0,说明程序正常退出,返回到主程序继续往下执行 。
2、return 1,说明程序异常退出,返回主调函数来处理 , 继续往下执行 。return 0或return 1对程序执行的顺序没有影响,只是大家习惯于使用return(0)退出子程序而已 。
c语言怎么用自定义函数排序#include stdio.h
#include string.h#define NUM 3
struct student
{
char name[20];/*姓名*/
long num;/*12位学号*/
double sum;/*总分*/
};
void Create_Students(struct student stu[NUM])
{
struct student *p;
printf("请输入学生姓名 学号(12位) 总分:\n");
for( p = stu; p stu NUM; p)
{
scanf("%s %d %lf",p-name,p-num,p-sum); }
}
void Order_Students(struct student stu[NUM])//起泡法
{
int i,j;
struct student temp;
for(i=NUM-1;i=0;i--)
for(j=0;ji;j)
if(stu[j].sumstu[j 1].sum)
{
temp = stu[j];
stu[j] = stu[j 1];
stu[j 1]=temp;
}
}
void main()
{
int i=1;
struct student *p;
struct student stu[NUM];
Create_Students(stu);
Order_Students(stu);
printf("%-20s %-13s %-6s %4s\n","姓名","学号(12位)","总成绩","名次");
for(p=stu;pstu NUM;p,i)
{
printf("%-20s %-13.0d %-8.2f -\n",p-name,p-num,p-sum,i);
}
}//你参考参考,嘿
C语言:输入5个数,用调用函数的方法,从小到大排序 用简单点的#includestdio.h
void sort(float *a, int n)
{
int i,j,tmp;
for(i=0; in-1; i)
for(j=0; jn-i-1; j)
if(a[j]a[j 1])
{
tmp = a[j];
a[j] = a[j 1];
a[j 1] = tmp;
}
}
void main()
{
float a[5];
int i;
printf("请输入五个数(逗号隔开):");
scanf("%f,%f,%f,%f,%f",a[0],a[1],a[2],a[3],a[4]);
sort(a,5);
printf("排序后为:");
for(i=0; i5; i)
printf("%.2f ",a[i]);
printf("\n");
}
或者三个数的 。
void sort(int *a, int *b, int *c)
{
int tmp;
if(*a*b){
tmp = *b;
*b = *a;
*a = tmp;
}
if(*a*c){
tmp = *c;
*c = *a;
*a = tmp;
}
if(*b*c){
tmp = *c;
*c = *b;
*b = tmp;
}
return;
}
扩展资料:
C语言中没有预置的sort函数 。如果在C语言中,遇到有调用sort函数,就是自定义的一个函数,功能一般用于排序 。
一、可以编写自己的sort函数 。
如下函数为将整型数组从小到大排序 。void sort(int *a, int l)//a为数组地址 , l为数组长度 。
{
int i, j;
int v;//排序主体
for(i = 0; il - 1; i)
for(j = i 1; jl; j)
{
if(a[i]a[j])//如前面的比后面的大,则交换 。
{
v = a[i];
a[i] = a[j];
a[j] = v;
}
}
}
对于这样的自定义sort函数,可以按照定义的规范来调用 。
二、C语言有自有的qsort函数 。
功 能: 使用快速排序例程进行排序 。头文件:stdlib.h
原型:
void qsort(void *base,int nelem,int width,int (*fcmp)(const void *,const void *));
参数:
1、待排序数组首地址 。
2、数组中待排序元素数量 。
3、各元素的占用空间大小4 指向函数的指针,用于确定排序的顺序,这个函数必须要自己写比较函数,即使要排序的元素是int , float一类的C语言基础类型 。
关于c语言的函数怎么排序和c语言调用函数排序数字的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。

    推荐阅读