###### 问题相关代码,请勿粘贴截图
#include<stdio.h>
int main()
{
int i;
int a[12];
printf("输入成绩:\n");
for (i = 0;i < 12;i++)
{
printf("a[%d]=", i);
scanf("%d", &a[i]);
}
int j;
for (i = 0;i < 12;i++)
{
for (j = 11;j >= i;j--)
{
if (a[j] > a[j - 1])
{
int temp = a[j - 1];
a[j - 1] = a[j];
a[j ] = temp;
}
}
}
for (i = 0;i < 12;i++)
{
printf("%d\t", a[i]);
if (i == 4)
printf("\n");
}
printf("\n");
return 0;
}
###### 运行结果及报错内容
异常是这个Run-Time Check Failure #2 - Stack around the variable 'a' was corrupted.a【11】之前都能打印 到了a【11】就变 -85899346
###### 我的解答思路和尝试过的方法
把a【12】变成a【13】没效果
###### 我想要达到的结果
内层越界了
最开始i为0的时候,内层j-1会访问到-1的位置
尝试改为
#include <stdio.h>
int main()
{
int i;
int a[12] = {1, 3, 4, 2, 5, 6, 3, 7, 12, 23, 44, 1};
// printf("输入成绩:\n");
// for (i = 0;i < 12;i++)
// {
// printf("a[%d]=", i);
// scanf("%d", &a[i]);
// }
int j;
for (i = 0; i < 12; i++)
{
for (j = 11; j > i; j--)
{
if (a[j] > a[j - 1])
{
int temp = a[j - 1];
a[j - 1] = a[j];
a[j] = temp;
}
}
}
for (i = 0; i < 12; i++)
{
printf("%d\t", a[i]);
if (i % 4 == 3)
printf("\n");
}
printf("\n");
return 0;
}
内循环for (j = 11; j >= i; j--) 应该改成j > i; 否则当外循环i=0时,如果j循环到最后也是0,a[j-1]就是a[-1]了
#include<stdio.h>
int main()
{
int i;
int a[12];
printf("输入成绩:\n");
for (i = 0;i < 12;i++)
{
printf("a[%d]=", i);
scanf("%d", &a[i]);
}
int j;
for (i = 0;i < 12;i++)
{
for (j = 11;j > i;j--)
{
if (a[j] > a[j - 1])
{
int temp = a[j - 1];
a[j - 1] = a[j];
a[j ] = temp;
}
}
}
for (i = 0;i < 12;i++)
{
printf("%d\t", a[i]);
if (i % 4 == 3)
printf("\n");
}
printf("\n");
return 0;
}
16行 j>=i是有问题的,改为j>i
因为循环中用到a[j-1],当外循环i=0时,如果j=i,那么a[j-1]就是a[-1]越界了