问答题

给定程序MODI1.C中的函数Creatlink的功能是创建带头结点的单向链表, 并为各结点数据域赋0到m-1的值。
请改正函数Creatlink中指定部位的错误, 使它能得出正确的结果。
注意: 不要改动main函数, 不得增行或删行, 也不得更改程序的结构!
给定源程序:
#include
#include
typedef struct aa
{ int data;
struct aa *next;
} NODE;
NODE *Creatlink(int n, int m)
{ NODE *h=NULL, *p, *s;
int i;
p=(NODE )malloc(sizeof(NODE));
h=p;
p->next=NULL;
for(i=1; i<=n; i++)
{ s=(NODE *)malloc(sizeof(NODE));
s->data=rand()%m; s->next=p->next;
p->next=s; p=p->next;
}
return p;
}
outlink(NODE *h)
{ NODE *p;
p=h->next;
printf("\n\nTHE LIST :\n\n HEAD ");
while(p)
{ printf("->%d ",p->data);
p=p->next;
}
printf("\n");
}
main()
{ NODE *head;
head=Creatlink(8,22);
outlink(head);
}

【参考答案】

第一处: 指向刚分配的结构指针,所以应改为:p=(NODE *)malloc(sizeof(NODE));
第......

(↓↓↓ 点击下方‘点击查看答案’看完整答案 ↓↓↓)
热门 试题

问答题
程序通过定义学生结构体变量,存储了学生的学号、姓名和3门课的成绩。所有学生数据均以二进制方式输出到文件中。函数fun的功能是重写形参filename所 指文件中最后一个学生的数据,即用新的学生数据覆盖该学生原来的数据,其它学 生的数据不变。 请在程序的下划线处填入正确的内容并把下划线删除, 使程序得出正确的结果。 注意:源程序存放在考生文件夹下的BLANK1.C中。 不得增行或删行,也不得更改程序的结构! 给定源程序: #include #define N 5 typedef struct student { long sno; char name[10]; float score[3]; } STU; void fun(char *filename, STU n) { FILE *fp; fp = fopen(__1__, rb+ ); fseek(__2__, -1L*sizeof(STU), SEEK_END); fwrite(&n, sizeof(STU), 1, __3__); fclose(fp); } main() { STU t[N]={ {10001, MaChao , 91, 92, 77}, {10002, CaoKai , 75, 60, 88}, {10003, LiSi , 85, 70, 78}, {10004, FangFang , 90, 82, 87}, {10005, ZhangSan , 95, 80, 88}}; STU n={10006, ZhaoSi , 55, 70, 68}, ss[N]; int i,j; FILE *fp; fp = fopen( student.dat , wb ); fwrite(t, sizeof(STU), N, fp); fclose(fp); fp = fopen( student.dat , rb ); fread(ss, sizeof(STU), N, fp); fclose(fp); printf( nThe original data : n n ); for (j=0; j{ printf( nNo: %ld Name: %-8s Scores: ,ss[j].sno, ss[j].name); for (i=0; i<3; i++) printf( %6.2f , ss[j].score[i]); printf( n ); } fun( student.dat , n); printf( nThe data after modifing : n n ); fp = fopen( student.dat , rb ); fread(ss, sizeof(STU), N, fp); fclose(fp); for (j=0; j{ printf( nNo: %ld Name: %-8s Scores: ,ss[j].sno, ss[j].name); for (i=0; i<3; i++) printf( %6.2f , ss[j].score[i]); printf( n ); } }