简单选择排序实现,为什么有时不能排出来,例如99 55 66 11 22

#include <stdio.h>
#define N 5

void Swap(int *a,int *b){//交换
	int temp;
	temp = *a;
	*a = *b;
	*b = temp;
}

void SimpleSS(int *a,int n){//简单选择排序
	int i,j,min,pos;
	for(i=0;i<n-1;i++){
		min=a[i];
		pos=i;
		for(j=i+1;j<n;j++){
			if(a[j]<min){
				min=a[j];
				pos=j;
			}
			Swap(&a[i],&a[pos]);
		}
	}
}

int main(){
	int i,a[N];
	printf("请输入5个数字:");
	for(i=0;i<N;i++){
		scanf("%d",&a[i]);
	}
	SimpleSS(a,N);
	printf("\n");
	for(i=0;i<N;i++)
		printf("%d ",a[i]);
	printf("\n");
	return 0;
}

 

#include <stdio.h>
#define N 5
void Swap(int *a,int *b){//交换
	int temp;
	temp = *a;
	*a = *b;
	*b = temp;
}
void SimpleSS(int *a,int n){//简单选择排序
	int i,j,min,pos;
	for(i=0;i<n;i++){
		min=a[i];
		pos=i;
		for(j=i+1;j<n;j++){
			if(a[j]<min){
				min=a[j];
				pos=j;
				Swap(&a[i],&a[pos]);
			}

		}
	}
}
int main(){
	int i,a[N];
	printf("请输入5个数字:");
	for(i=0;i<N;i++){
		scanf("%d",&a[i]);
	}
	SimpleSS(a,N);
	printf("\n");
	for(i=0;i<N;i++)
		printf("%d ",a[i]);
	printf("\n");
	return 0;
}

如果对你有帮助请点下采纳,谢谢!

Swap(&a[i],&a[pos]); 放到22行后面

您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

有时不能排出来,那就是代码有问题