解题思路:

感觉这样模块化会好一些~



注意事项:


注意指针的使用


参考代码:

/*
选择排序
*/
#include<stdio.h>
void swap(int *a,int *b);
void sort(int *arr);
void swap(int *a,int *b)//交换模块,用了指针
{
    int temp;
    temp = *a;
    *a = *b;
    *b = temp;
}
void sort(int *arr)//选择排序模块
{
    int i,min,j;
    for(i = 0; i < 10; i++)
    {
        min = i;//min用来记录最小值的下标
        for(j = i+1; j < 10; j++)
            if(arr[min] > arr[j])
                min = j;
        swap(arr+i,arr+min);
    }
}
int main()
{
    int arr[10];
    int i;
    for(i = 0; i < 10; i++)
        scanf("%d",arr+i);
    sort(arr);
    for(i = 0; i < 10; i++)
        printf("%d\n",*(arr+i));
    return 0;
}


点赞(4)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论