insertSort:订单号超过2 ^ 32

时间:2018-10-04 15:40:32

标签: c long-integer insertion-sort

我正在实现InsertionSort算法,但必须在数字大于2 ^ 32的特定数据集上运行它。为简单起见,我创建了一些示例来测试程序。

#include <stdio.h> 

void insertionSort(unsigned long long a[]) {
    int i, j;
    int key;

    for(i = 1; i < 4; i++) {
        key = a[i];
        j = i-1;

        while(j >= 0 && a[j] > key) {
            a[j+1] = a[j]; 
            j = j-1; 
        }
        a[j+1] = key;
    }
}

int main() {
    // example array
    unsigned long long c [] = {40000000000LL, 10000000000LL, 20000000000LL, 30000000000LL};

    printf("Before insertionSort: \n");
    for(int i = 0; i < 4; i++) { printf("%llu,\n", c[i]); }

    printf("\n");

    insertionSort(c);

    printf("After insertionSort: \n");
    for(int i = 0; i < 4; i++) { printf("%llu,\n", c[i]); }
    printf("\n");

    return 0;
}

,终端上的输出如下:

Before insertionSort:
40000000000,
10000000000,
20000000000,
30000000000,

After insertionSort:
1410065408,
40000000000,
18446744072234715136,
18446744073644780544,

这是一个奇怪的输出!有人知道我的错误在哪里吗?我只想以正确的方式打印数组!

1 个答案:

答案 0 :(得分:0)

key值的类型必须为unsigned long long才能起作用。