#include <stdio.h>
//输入数组并排序输出
int main()
{
int arr[10];
//数组输入
for(int i=0;i<10;i++)
{
printf("请输入第%d个数:\n",i+1);
scanf("%d", &arr[i]);
}
//数组输出显示
for(int i=0;i<10;i++)
{
printf("%d ",arr[i]);
}
printf("\n");
//1) 选择排序
for( int i = 0;i < 10 -1 ; i++ )
{//外层循环 分别找到小值
int mi = i;//记录最小值下标
int min = arr[i]; //记录最小值
for(int k = i; k < 10; k++)
if(min > arr[k])
{
min = arr[k];
mi = k;
}
arr[mi] = arr[i];
arr[i] = min;
}
//数组输出显示
for(int i=0;i<10;i++)
{
printf("%d ",arr[i]);
}
printf("\n");
return 0;
}
冒泡排序:
//2) 冒泡排序
for(int i=0; i < 10-1 ; i++) //对每个数进行冒泡
{
int flag = 0;//标志位
for(int k = 0; k < 10-1-i; k++)
{
if(arr[k] > arr[k+1]) // 异或交换位置将大的数往后移动
{
arr[k] ^= arr[k+1];
arr[k+1] ^= arr[k];
arr[k] ^= arr[k+1];
flag = 1;
}
}
if(flag == 0) break;
}
运行结果图 :
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GsEE7X56-1660524686423)(C:\Users\huang li yue\AppData\Roaming\Typora\typora-user-images\image-20220814213615623.png)]
在网上找了好久的方法,没有找到自己想要的 。于是根据老师教过的方法实现了第一次代码复现,蛮开心,发出来分享一下,新人一枚大佬请略过!
在网上找了好久的方法,没有找到自己想要的 。于是根据老师教过的方法实现了第一次代码复现,蛮开心,发出来分享一下,新人一枚大佬请略过!