c语言实时排序程序

c语言实时排序程序,第1张

#include "stdio.h"

#include "stdlib.h"

#define MAX_NUM 100

int main( int argc, char *argv[] )

{

    int sort_list[MAX_NUM]

    int tmp_it = 0

    int list_num = 0

    int i, j, k, t

    while ( 1 )

    {

        scanf( "%d", &tmp_it )

        if ( tmp_it < 0 || list_num >= MAX_NUM )

        {

            break

        }

        sort_list[list_num++] = tmp_it

        for ( i = 0 i < list_num - 1 i ++ )

        {

            k = i

            for ( j = i + 1 j < list_num j ++ )

                if ( sort_list[ k ] > sort_list[ j ] )

                {

                    k = j

                }

            if ( k != i )

            {

                t = sort_list[ i ]

                sort_list[ i ] = sort_list[ k ]

                sort_list[ k ] = t

            }

        }

        printf( "开始打印排序\n" )

        for ( i = 0 i < list_num i++ )

        {

            printf( "%d\n", sort_list[i] )

        }

        printf( "打印排序结束\n" )

    }

    return 0

}

楼上的用的是C++

若单纯的用C那就是这样

#include<stdio.h>

#define

print

"NO.%d

%d

%d

%d

%d

%3.2f

%3.2f\n",1+i,stu[i].num,stu[i].mat,stu[i].ENG,stu[i].com,stu[i].aver,stu[i].total//宏定义节约时间

struct

student

{

int

num

int

mat

int

ENG

int

com

float

aver

float

total

}stu[10]//定义结构体变量

void

main()

{

int

i

void

take_turn_print(struct

student

stu1[10])

float

sum(int

x,int

y,int

z)//声明求和函数

for(i=0i<10i++)

scanf("%d%d%d%d",&stu[i].num,&stu[i].mat,&stu[i].ENG,&stu[i].com)

for(i=0i<10i++)

{

stu[i].total=sum(stu[i].mat,stu[i].ENG,stu[i].com)//调用求和函数

stu[i].aver=stu[i].total/3

}

take_turn_print(stu)//调用排序

打印函数

}

void

take_turn_print(struct

student

stu1[10])

{

void

change(int

*x,int

*y)//声明换位函数

void

change1(float

*x,float

*y)//声明换位函数

int

i,j

for(j=0j<9j++)//冒泡排序

为理解简单

就没用别的排序方法

哈哈

{

for(i=0i<9-ji++)

{

if(stu1[i].aver<stu1[i+1].aver)

{

change(&stu1[i].num,&stu1[i+1].num)//

值交换

change(&stu1[i].mat,&stu1[i+1].mat)//

值交换

change(&stu1[i].ENG,&stu1[i+1].ENG)//

值交换

change(&stu1[i].com,&stu1[i+1].com)//

值交换

change1(&stu1[i].aver,&stu1[i+1].aver)//

值交换

change1(&stu1[i].total,&stu1[i+1].total)//

值交换

}

}

}

for(i=0i<10i++)

printf(print)//打印

}

void

change(int

*x,int

*y)

{

int

i

i=*x

*x=*y

*y=i//利用指针做变量替换

}

void

change1(float

*x,float

*y)

{

float

i

i=*x

*x=*y

*y=i//利用指针做变量替换

}

float

sum(int

x,int

y,int

z)

{

float

i

i=(float)(x+y+z)

return(i)

}

前几天也是帮同学做这样的题

一模一样

看来你也是WH大学的


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11013275.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-13
下一篇 2023-05-13

发表评论

登录后才能评论

评论列表(0条)

保存