[分享] 单班计程11.2 测试用main

楼主: fei6409 (fei6409)   2010-11-30 20:20:33
有鉴于这题不少人卡在莫名其妙的bug(?)
就放个简单的测试在上面囉~
然后小小的建议,做完malloc后最好对拿到的内存初始化一下,
比较不容易出错这样,
像是讲义上的 assert(); 就是为了避免没初始化的情形发生~
#include<stdio.h>
#include<stdlib.h>
struct listnode{
int data;
struct listnode *next;
};
/*
put your code here.
*/
void print(struct listnode *now){
while(now!=NULL){
printf("%d ", now->data);
now=now->next;
}
puts("");
return;
}
int main(){
int i;
struct listnode *list1, *list2, *ptr, *now;
list1=(struct listnode*)malloc(sizeof(struct listnode));
list2=(struct listnode*)malloc(sizeof(struct listnode));
for(i=0, now=list1; i<10; i+=2){
ptr=(struct listnode*)malloc(sizeof(struct listnode));
ptr->next=NULL;
ptr->data=i;
now->next=ptr;
now=now->next;
}
list1=list1->next;
printf("now print the content of list1\n");
print(list1);
for(i=1, now=list2; i<10; i+=2){
ptr=(struct listnode*)malloc(sizeof(struct listnode));
ptr->next=NULL;
ptr->data=i;
now->next=ptr;
now=now->next;
}
for( ; i<=15; i++){
ptr=(struct listnode*)malloc(sizeof(struct listnode));
ptr->next=NULL;
ptr->data=i;
now->next=ptr;
now=now->next;
}
list2=list2->next;
printf("now print the content of list2\n");
print(list2);
now=merge_linked_lists(list1, list2);
printf("now print the content of your list\n");
print(now);
return 0;
}
作者: m80126colin (许胖)   2009-01-30 20:59:00
推真强者
作者: wctaiwan (wctaiwan)   2009-01-30 23:26:00
感谢,今天弄超久的
作者: rod24574575 (天然呆)   2009-01-30 23:31:00
然后11.2传上去时好像要自己附一下标头档我一开始没附结果他跟我说NULL不能用...
楼主: fei6409 (fei6409)   2010-02-01 00:01:00
应该是11.3? 我是传这题才有用标头档...
作者: m80126colin (许胖)   2010-02-01 00:20:00
我也是有用到标头档.......如果NULL写成0就不用??
作者: rod24574575 (天然呆)   2010-02-01 00:33:00
喔 我有点忘记是哪个了 反正都附就不会错 (?
作者: garychou (天然卷都是好人)   2010-02-01 22:58:00
虽然我写好了 还是推一下囉 第三题的确要传标头档
作者: sandy30716 (达)   2010-02-01 23:17:00
第三题有测试用的吗?

Links booklink

Contact Us: admin [ a t ] ucptt.com