原题链接:[编程入门]选择排序
解题思路:
感觉这样模块化会好一些~
注意事项:
注意指针的使用
参考代码:
/*
选择排序
*/
#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;
}0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复