2012-11-27 78 views
2

當用戶在鏈接列表中輸入單個字符時,程序應打印出列表,但是當輸入字符時遇到問題,不會打印字符並導致無限循環,但在輸入數字時工作正常。有任何想法嗎?如何打印出單個鏈接列表中的字符?

 #include <stdio.h> 
     #include "stdafx.h" 
     #include <stdlib.h> 
     #include <malloc.h> 

     /*Structure containing a Data part & a Link part to the next node in the List */ 

     struct Node 
     { 
      int Data; 
      struct Node *Next; 
     }*Head; 



     int count() 
     { 
     /* Counting number of elements in the List*/ 
      struct Node *cur_ptr; 
      int count=0; 

      cur_ptr=Head; 

      while(cur_ptr != NULL) 
      { 
      cur_ptr=cur_ptr->Next; 
      count++; 
      } 
      return(count); 
     } 


     void addEnd(char input) 
     { 
      struct Node *temp1, *temp2; 

      temp1=(struct Node *)malloc(sizeof(struct Node)); 
      temp1->Data=input; 

      // Copying the Head location into another node. 
      temp2=Head; 

      if(Head == NULL) 
      { 
       // If List is empty we create First Node. 
       Head=temp1; 
       Head->Next=NULL; 
      } 
      else 
      { 
       // Traverse down to end of the list. 
       while(temp2->Next != NULL) 
       temp2=temp2->Next; 

       // Append at the end of the list. 
       temp1->Next=NULL; 
       temp2->Next=temp1; 
      } 
     }  

     // Displaying list contents 

     void display() 
     { 
      struct Node *cur_ptr; 

      cur_ptr=Head; 

      if(cur_ptr==NULL) 
      { 
      printf("\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~"); 
      printf("\nList is Empty "); 
      printf("\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\n\n\n"); 
      } 
      else 
      { 
       printf("\nElements in the List:\n\n "); 
       //traverse the entire linked list 
       while(cur_ptr!=NULL) 
       { 
        printf(" \n-> %d ",cur_ptr->Data); 
        cur_ptr=cur_ptr->Next; 
       } 
       printf("\n"); 
      } 
     } 

     int main(int argc, char *argv[]) 
     { 
     int i=0; 

     //Set HEAD as NULL 
     Head=NULL; 

     while(1) 
     { 

      printf("\n\n\n\n\n MENU\n"); 
      printf("---------------------------------\n"); 
      printf(" \n1. Insert one part of DNA sequence"); 
      printf(" \n2. Print the Elements in the List"); 
      printf(" \n\n3. Exit\n"); 
      printf(" \nChoose Option: "); 
      scanf("%d",&i); 

      switch(i) 
      { 
       case 1: 
       { 
        char dnaChar; 
        printf(" \nEnter char to be inserted into the List i.e A, T, G, C: "); 
        scanf("%d",&dnaChar); 
        addEnd(dnaChar); 
        display(); 
        break; 
       }  

       case 2: 
       { 
        display(); 
        break; 
       } 


       case 3: 
       { 
        struct Node *temp; 

        while(Head!=NULL) 
        { 
         temp = Head->Next; 
         free(Head); 
         Head=temp; 
        } 
        exit(0); 
       } 

       default: 
       { 
        printf("\nWrong Option \n\n\n\n"); 
       } 
      } 
     } 
     } 
+2

'scanf(「%d」)'需要輸入一個數字。嘗試獲取輸入爲字符串或字符,然後將其轉換回來。 –

回答

2

變化scanf("%d",&dnaChar)scanf("%c",&dnaChar)因爲dnaCharchar類型。

它將開始爲角色工作

2

你在你的數據類型是很不一致:

struct Node 
    { 
     int Data; // a "Node's Data is an int 
     ... 

然後在main()

   char dnaChar; // You say you want a char 
       printf(" \nEnter char to be inserted into the List i.e A, T, G, C: "); 
       scanf("%d",&dnaChar); // then scanf using the int type %d 

當你打印的清單:

   printf(" \n-> %d ",cur_ptr->Data); // You're printing int type 

所以你有一個問題,不一致。你需要爲你的數據類型選擇一個字符或一個int。變化:

scanf("%d",&dnaChar); 

scanf("%c",&dnaChar); 

將解決這個無限循環,現在你的數據將顯示爲ASCII值:

A => 65 
T => 84 
G => 71 
C => 67 

或者你也可以改變一切,以char/%c你會得到你的數據顯示爲A/T/G/C哪些IM O更容易閱讀。

末點:

當您切換到scanf("%c",&dnaChar);您的代碼將在differen的方式打破。當您進入菜單選項時,scanf不會消耗換行符。所以你需要這樣做,否則你就可以直接跳過ATGC條目:

printf("\n\n\n\n\n MENU\n"); 
printf("---------------------------------\n"); 
printf(" \n1. Insert one part of DNA sequence"); 
printf(" \n2. Print the Elements in the List"); 
printf(" \n\n3. Exit\n"); 
printf(" \nChoose Option: "); 
scanf("%d",&i); 
getchar(); // <-- Add this to get rid of newline