|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 houqing1999 于 2023-6-24 20:35 编辑
这个代码不能运行,怎么修改,使用的是VisualStudio 如图
- #define _CRT_SECURE_NO_WARNINGS 1//归并排序
- #include <stdio.h>
- void merge_sort(int array[], int length);
- void merge_sort_recursive(int array[], int reg[], int start, int end);
- void merge_sort_recursive(int array[], int reg[], int start, int end)
- {
- if (start >= end)
- {
- return;
- }
- int k = start;
- int length = end - start;
- int mid = (length / 2) + start;
- int start1 = start, end1 = mid;
- int start2 = mid + 1, end2 = end;
- merge_sort_recursive(array, reg, start1, end1);
- merge_sort_recursive(array, reg, start2, end2);
- while (start1 <= end1 && start2 <= end2)
- {
- reg[k++] = array[start1] < array[start2] ? array[start1++] : array[start2++];
- }
- while (start1 <= end1)
- {
- reg[k++] = array[start1++];
- }
- while (start2 <= end2)
- {
- reg[k++] = array[start2++];
- }
- for (k = start; k <= end; k++)
- {
- array[k] = reg[k];
- }
- }
- void merge_sort(int array[], int length)
- {
- int reg[length];
- merge_sort_recursive(array, reg, 0, length - 1);
- }
- int main(void)
- {
- int array[] = { 73, 108, 111, 118, 101, 70, 105, 115, 104, 67, 46, 99, 111, 109 };
- int i, length;
- length = sizeof(array) / sizeof(array[0]);
- merge_sort(array, length);
- printf("排序后的结果是:");
- for (i = 0; i < length; i++)
- {
- printf("%d ", array[i]);
- }
- putchar('\n');
- return 0;
- }
复制代码
这个问题发生在 Visual Studio 环境中,它不支持变长数组(Variable Length Array,VLA)。在 C99 标准中引入了变长数组,但是 C++ 和某些 C 编译器(包括 Visual Studio 的 MSVC 编译器)并不支持这个特性。在你的代码中,你试图根据输入的参数创建一个数组,这在 Visual Studio 中是不允许的。
这个问题的解决方案是使用动态内存分配。下面是一个修复后的版本:
- #define _CRT_SECURE_NO_WARNINGS 1
- #include <stdio.h>
- #include <stdlib.h>
- void merge_sort(int array[], int length);
- void merge_sort_recursive(int array[], int reg[], int start, int end);
- void merge_sort_recursive(int array[], int reg[], int start, int end)
- {
- if (start >= end)
- {
- return;
- }
- int length = end - start;
- int mid = (length / 2) + start;
- int start1 = start, end1 = mid;
- int start2 = mid + 1, end2 = end;
- int k = start;
- merge_sort_recursive(array, reg, start1, end1);
- merge_sort_recursive(array, reg, start2, end2);
- while (start1 <= end1 && start2 <= end2)
- {
- reg[k++] = array[start1] < array[start2] ? array[start1++] : array[start2++];
- }
- while (start1 <= end1)
- {
- reg[k++] = array[start1++];
- }
- while (start2 <= end2)
- {
- reg[k++] = array[start2++];
- }
- for (k = start; k <= end; k++)
- {
- array[k] = reg[k];
- }
- }
- void merge_sort(int array[], int length)
- {
- int* reg = (int*)malloc(length * sizeof(int)); // 使用 malloc 创建动态数组
- merge_sort_recursive(array, reg, 0, length - 1);
- free(reg); // 使用完毕后,别忘了释放内存
- }
- int main(void)
- {
- int array[] = { 73, 108, 111, 118, 101, 70, 105, 115, 104, 67, 46, 99, 111, 109 };
- int i, length;
- length = sizeof(array) / sizeof(array[0]);
- merge_sort(array, length);
- printf("排序后的结果是:");
- for (i = 0; i < length; i++)
- {
- printf("%d ", array[i]);
- }
- putchar('\n');
- return 0;
- }
复制代码
在这个修复版本中,我使用了 malloc() 函数来创建一个动态数组。记住,当你使用 malloc() 为一个变量分配内存时,你需要在后面使用 free() 来释放这个内存,避免内存泄露。
|
|