Algorithms IN C中随书代码能否有问题

C语言 码拜 8年前 (2017-04-13) 936次浏览
问一下红色部分能否内存越界?
#include <stdio.h>
#include <stdlib.h>
typedef int Item;
#define key(A) (A)
#define less(A, B) (key(A) < key(B))
#define exch(A, B) { Item t = A; A = B; B = t; }
#define compexch(A, B) if (less(B, A)) exch(A, B)
void sort(Item a[], int l, int r)
{ int i, j;
for (i = l+1; i <= r; i++)
for (j = i; j > l; j–)
compexch(a[j-1], a[j]);
}
main(int argc, char *argv[])
{ int i, N = atoi(argv[1]), sw = atoi(argv[2]);
int *a = malloc(N*sizeof(int));
if (sw)
for (i = 0; i < N; i++)
a[i] = 1000*(1.0*rand()/RAND_MAX);
else
while (scanf(“%d”, &a[N]) == 1) N++;
sort(a, 0, N-1);
for (i = 0; i < N; i++) printf(“%3d “, a[i]);
printf(“\n”);
}
解决方案

40

会越界Algorithms IN C中随书代码能否有问题

CodeBye 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 , 转载请注明Algorithms IN C中随书代码能否有问题
喜欢 (0)
[1034331897@qq.com]
分享 (0)