csci4061/notes/01-introduction-code/read_all_numbers_user.c

32 lines
1.5 KiB
C
Raw Normal View History

2018-01-29 23:28:37 +00:00
// Simple demonstration of reading user input using a linked list with
// dynamic memory allocation.
#include <stdio.h>
#include <stdlib.h>
typedef struct int_node_struct { // Definition of a node
int data; // integer data
struct int_node_struct *next; // link to another node
} int_node;
int_node* head = NULL; // global variable, front of list
int main(int argc, char **argv){
int x;
printf("Enter numbers; Ctrl-D to end input:\n");
while(fscanf(stdin,"%d",&x) != EOF){ // read a number, check for end of input
int_node *new = malloc(sizeof(int_node)); // allocate space for a node
new->data = x; // set data, -> derefernces and sets
new->next = head; // point at previous front of list
head = new; // make this node the new front
}
int_node *ptr = head; // prepare to iterate through list
int i=0;
printf("\nEntire list\n");
while(ptr != NULL){ // iterate until out of nodes
printf("list(%d) = %d\n",i,ptr->data); // print data for one node
ptr = ptr->next; // move pointer forward one node
i++;
}
return 0; // Should free list but program is ending
} // so memory will automatically return to system