0

項目を追加してそれらの項目を表示するリンク リスト プログラムを作成しています。最初の項目は正常に追加できますが、2 番目の項目の追加中にエラーが発生します。エラーを理解しようとしましたが、すべて問題ないようです。プログラムがハングします。私のコードは次のとおりです。

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

struct link_list
 {
  int number;
  struct link_list *next;
 };

 typedef struct link_list node;
 node *head;

 void add(int num)
 {
   node *newnode,*current;
   newnode = (node *)malloc(sizeof(node));
   newnode->number = num;
   newnode->next = NULL;
  if(head == NULL)
   {
     head = newnode;
     current = newnode;
   }
 else
   {
     current->next = newnode;
     current = newnode;
   }
}

void display(node *list)
{
 list = head;
 if(list == NULL)
  {
     return;
  }
 while(list != NULL)
 {
     printf("%d",list->number);
     list = list -> next;
 }
 printf("\n");
}

int  main()
 {
 int i,num;
 node *n;
 head=NULL;
 while(1)
  {
    printf("\nList Operations\n");
    printf("===============\n");
    printf("1.Insert\n");
    printf("2.Display\n");

    printf("3.Exit\n");
    printf("Enter your choice : ");
    if(scanf("%d",&i)<=0)
    {
        printf("Enter only an Integer\n");
        exit(0);
    }
    else
    {
        switch(i)
        {
            case 1:
                     printf("Enter the number to insert : ");
                     scanf("%d",&num);
                     add(num);
                     break;
            case 2:
                   if(head==NULL)
                    {
                    printf("List is Empty\n");
                    }
                    else
                    {
                    printf("Element(s) in the list are : ");
                    }
                    display(n);
                    break;
            case 3:     return 0;
            default:    printf("Invalid option\n");
        }
    }
  }
  return 0;
}
4

2 に答える 2

3

問題は、current関数呼び出し間で持続しないという値にあります。関数の外側 (つまり、head宣言のすぐ下) に移動するか、 として宣言しstaticます。

于 2013-06-28T15:12:23.587 に答える
1

1 つの変更のみ、void add のスコープ外で現在のポインターを定義します。

ノード*ヘッド、*現在;

ここに正しいコードがあります

struct link_list
 {
  int number;
  struct link_list *next;
 };

 typedef struct link_list node;
 node *head,*current;

void add(int num)
{
node *newnode;
newnode = (node *)malloc(sizeof(node));
newnode->number = num;
newnode->next = NULL;
 if(head == NULL)
 {
 head = newnode;
 current = newnode;
 }
else
 { 
 current->next = newnode;
 current = newnode;
 }
 }
于 2013-12-26T08:41:12.823 に答える