选择排序算法(C)

问题描述 投票:0回答:1

我正在尝试研究一些算法问题,但找不到启动我的选择排序算法代码的方法。我使用 Visual Studio,代码在编译时没有显示任何错误。当我启动代码时,系统只会停止几秒钟并打印“按任意键继续...”。我是初学者,我看不出有什么问题。帮助我

#include <stdio.h>

int n = 6;

int qwerty(int a[]) {
    int i, j, t;
    for (i=1; i<=n-1; i++){
        for (j=i+1; j<=n; j++){
            if (a[i] > a[j]){
                t = a[j]; 
                a[j] = a[i]; 
                a[i] = t;
            }
        }
    }
}

int main(void) {
    int a[6] = { 2, 14, 20, 8, 17, 13 };
    qwerty(a[n]);
    int i;
    for (i = 1; i <= n; i++){
        printf("%d ", a[i]);
    }
}
c algorithm sorting compilation
1个回答
2
投票

在 C 语言中,数组从 0 开始索引,最后一个元素位于索引 n-1 处。因此,您应该更改的第一件事是循环为

for(i = 0; i < n-1; i++)
for(j = i + 1; j < n; j++)

此外,这是一种冒泡排序算法,而不是选择排序。选择排序算法可以在任何地方找到,所以我不会在这里输入它。

© www.soinside.com 2019 - 2024. All rights reserved.