循环变量显示垃圾值

时间:2013-08-17 14:30:32

标签: c linked-list

我正在编写一个程序,用于返回一个字符串,该字符串具有链表中节点中所有字符串的串联,直到连接字符串的总大小不等于特定字节数。但是循环变量的值在最后一次迭代中变成了垃圾。谁能告诉我为什么?

typedef struct li {
    char *data;
    int len;              //structure for the linked list
    struct li *next;
} node ;

node *head;


void create()
{
     int i,n;
     char num[100];               //the value of i when equal to n-1 becomes garbage
                                   //of the proper n-1
     node *temp;
     printf("enter the number of nodes\n");
     scanf("%d",&n);             //supposed to create the list
     printf("n=%d",n);
     printf("enter the strings to be kept in the nodes\n");

     for(i=0;i<n;i++) {

         if(i==0) {
             head=(node*)malloc(sizeof(node));
             temp=head;
         }
         else {
             temp->next=(node*)malloc(sizeof(node));
             temp=temp->next;
         }

         scanf("%s",num);
         temp->data=num;
         temp->len=strlen(num);
         //in the final loop shows error as value of i becomes garbage
     }
     temp->next=NULL;
}


void g(int n)
{
    int t=0,m;     //the main logic
    char *f={'\0'};
    node *temp;
    temp=head;

    while(temp!=NULL && t!=n) {
        m=sizeof(temp->data);
        strcat(f,temp->data);
        t+=m;
        temp=temp->next;
    }

}

1 个答案:

答案 0 :(得分:2)

使用scanf从用户读取字符串,并将其放在本地数组中。第一个问题是您使所有节点指针指向此本地数组。第二个问题是它是一个本地变量,一旦函数返回就无效。

解决此问题的最简单方法是使用strdup函数复制字符串。请记住,您必须free该文字。