C PROGRAMMING
C Tokens
The smallest individual unit in a c program is known as a token. C tokens can
be classified as
1) Keywords
2) Identifiers
3) Constants
4) Strings
5) Special Symbols
6) Operators
                 Keyword
• Keywords are the words that convey a special
  meaning to the compiler. The keywords
  cannot be used as variable names because by
  doing so, we are trying to assign a new
  meaning to the keyword which is not
  allowed.
• Eg:- auto,break,case etc.....
                 Identifiers
• Identifiers are used as the general terminology
  for the names of variables,functions and
  arrays.
• Eg:- ab,temp etc......
                 Constants
• Constant refers to the data items that do not
  change their value during the program
  execution. Several types of constant that are
  allowed in c are:
            Integer constants
• Integer constants are whole numbers
• without any fractional part. It must have at
  least one digit and may contain either + or –
  sign. A number with no sign is assumed to be
  positive.
                     Real constants
• The numbers having fractional parts are called real or floating point
  constants. These may be represented in one of the two forms called
  fractional form or the exponent form and may also have either + or
  – sign preceding it. Example of valid real constants in fractional
  form or decimal notation 0.05, -0.905, 562.05, 0.015.
• The general format in which a real number may be represented in
  exponential or scientific form is mantissa e exponent. The mantissa
  must be either an integer or a real number expressed in decimal
      notation. The letter e separating the mantissa and the
  exponent can also be written in uppercase i.e. E And, the exponent
  must be an integer. Examples of valid real constants in exponent
  form are: 252E85, 0.15E-10, -3e+8
           Character constants
• A character constant contains one single
  character enclosed within single quotes.
  Examples of valid character constants ‘a’,‘Z’,‘5’
                   Escape characters
• C allows us to have certain non graphic characters in character constants.
Escape Sequence           Description
\a                        Audible Alert(bell)
\b                        Back space
\n                        New line
\t                        Horizontal tab
\v                        Vertical tab
\f                        Form feed
\r                        Carriage return
\“                         Double quotation mark
\‘                         Single quotation mark
\?                         Quetion mark
             String constants
• String constants are sequence of characters
  enclosed within double quotes. Eg:- “hello”.
• Every sting constant is automatically
  terminated with a special character ‘\0’ called
  the null character which represents the end of
  the string.
Data Types
                     Data Types
• Data types simply refers to the type and size of data
  associated with variables and functions.
Data types
• Fundamental data types
• Integer
• Float
• Character
Derived data types
• Arrays
• Pointers
• Structures
• Enumeration
          int-Integer data types
• Integers are whole numbers that can have
  both positive and negative values but no
  decimal values. Example: 0, -5, 10
• In C programming, keyword int is used for
  declaring integer variable. For example:
• int id;
• int id,age;
            float-Floating types
• Floating type variables can hold real numbers
  such as: 2.34, -9.382, 5.0 etc. You can declare
  a floating point variable in C by using either
  float or double keyword. For example:
• float accountbalance;
• double bookprice;
 Difference between float and double
• The size of float (single precision float data
  type) is 4 bytes. And the size of double (double
  precision float data type) is 8 bytes. Floating
  point variables has a precision of 6 digits
  whereas the precision of double is 14 digits.
           Char-Character type
• Keyword char is used for declaring character
  type variables. For example:
• char test=’h’;
• The size of character variable is 1 byte.
                  Qualifiers
• Qualifiers alters the meaning of base data
  types to yield a new data type.
                Size qualifiers
• Size qualifiers alters the size of a basic type.
  There are two size qualifiers, long and short.
  For example:
• long double I;
• The size of double is 8 bytes. However, when
  long keyword is used, that variable becomes
  10 bytes.There is another keyword short which
  can be used if you previously know the value
  of a variable will always be a small number.
               Sign qualifiers
• Integers and floating point variables can hold
  both negative and positive values. However, if
  a variable needs to hold positive value only,
  unsigned data types are used. For example:
• unsigned int a;
• There is another qualifier signed which can
  hold both negative and positive only.
            Constant qualifiers
• An identifier can be declared as a constant. To
  do so const keyword is used.
• Const int cost=20;
• The value of cost cannot be changed in the
  program.
Input Output(I/O): printf() and scanf()
• C programming has several in built library
  functions to perform input and output tasks.
  Two commonly used functions for I/O
  (Input/Output) are printf() and scanf().The
  scanf() function reads formatted input from
  standard input (keyboard) whereas the printf()
  function sends formatted output to the
  standard output (screen).
                  Operators
• Depending on the number of operands that an
  operator can act upon, operators can be classified
  as
• 1. Unary Operators: Those operators that require
  only single operand to act upon are known as
  unary operators.
• 2. Binary Operators: Those operators that require
  two operands to act upon are called binary
  operators.
• 3. Ternary Operators: These operators requires
  three operands to act upon.
                      Arithmetic Operators
Operator       Meaning
+          Addition
-          Substraction
*          Multiplication
/          Division
%          Remainder after division
 Increment and Decrement Operators
• C programming has two operators increment
  ++ and decrement -- to change the value of an
  operand (constant or variable) by 1
• Increment ++ increases the value by 1
  whereas decrement -- decreases the value by
  1. These two operators are unary operators,
  meaning they only operate on a single
  operand.
          Assignment Operators
• An assignment operator is used for assigning a
  value to a variable.
             Relational Operator
Operator      Meaning              Example
==    Equal to                5==3 returns 0
>     greater than            5>3 returns 1
<     Less than               5<3 returns 0
!=    not equal to            5!=3 returns 1
>= greater than or equal to   5>=3 returns 1
<= Less than or equal to      5<=3 returns 0
              Logical Operators
• An expression containing logical operator returns
  either 0 or 1 depending upon whether expression
  results true or false. Logical operators are
  commonly used in decision making in C
  programming.
Operators             Meaning
&&                     Logical AND
||                     Logical OR
!                      Logical NOT
            Bitwise Operators
Operators
&
|
^
~
<<
>>
             Comma Operator
• Comma operators are used to link related
  expressions together.For example:
  int a,c=5,d;
            The sizeof operator
• The sizeof is an unary operator which returns
  the size of data (constant, variables, array,
  structure etc).
             Ternary Operator
• A conditional operator is a ternary operator,
  that is, it works on 3 operands.
       Conditional Operator Syntax
• conditionalExpression ? expression1 : expression2
• The conditional operator works as follows:
• The first expression conditionalExpression is
  evaluated at first. This expression evaluates to 1 if
  it's and evaluates to 0 if it's false.
• If conditionalExpression is true, expression1 is
  evaluated.
• If conditionalExpression is false, expression2 is
  evaluated.
           Looping statements
• There are 3 looping statements,They are
  while,do….while and for loop.
                   While loop
The syntax is,
while(condition)
{
     statement;
     inc/dec;
}
                    do….while
The syntax is,
do
{
     statement;
     inc/dec;
}
while(condition);
                    for loop
The syntax is
for(initialization;condition;inc/dec)
{
      statement;
}
       Decision making statements
The decision making statements are if and if...else.
The syntax of if… else is
if(condition)
{
      statement;
}
else
{
      statement;
}
                          switch statement
•   It is a multi decision statement. Its syntax is
switch(exp)
{
         case1: statement;
                                break;
          case2: statement;
                                break;
          .
          .
          .
Casen: statement;
                                break;
default: statement;
                                break;
}
                      Array
• int a; means It has one memory location with
  unknown address can store one integer number.
• Int a[3]; means it have three memory location
  can store three integer number,Numbered from
  0,1,2.
• In array concept we can store two or more data.
  It share same name.
• In this, [3] named as suscript or index number. If
  we have one suscript that is one dimensional
  array. If we have two suscript that is two
  dimensional or multidimentional array.
                         Strings
• Two or more characters enclosed within a double
  quotes. Eg- “hello”.
• ‘\0’ denotes end of character.
• Gets() is used to input or read a string. Puts() is used to
  output or display a string. If we use these two function
  we must declare #include<string.h>.
• strlen()-to find length of a string.
• Strrev()-to reverse a string.
• Strcpy()-to copy a string.
• Strcat()-to concatinate the strings.
• Strcmp()-compare two strings.
                  Functions
• Functions are the main building blocks in C.
  Functions have three parts.
• 1. Function declaration
• 2. Function calling
• 3. Function defenition
      Classification of Function
• Function with argument with return type
• Function with argument without return type
• Function without argument without return
  type
        Introduction to structures
• Arrays allow to define type of variables that
  can hold several data items of the same kind.
  Similarly structure is another user defined
  data type available in C that allows to combine
  data items of different kinds.
                          Defining a Structure
•     To define a structure, you must use the struct statement. The struct statement defines a new data
      type, with more than one member. The format of the struct statement is as follows −
• struct [structure tag]
    { member definition;
      member definition;
      ...
      member definition;
     } [one or more structure variables];
The structure tag is optional and each member definition is a normal variable definition, such as int i; or
float f; or any other valid variable definition. At the end of the structure's definition, before the final
semicolon, you can specify one or more structure variables but it is optional. Here is the way you would
declare the Book structure −
    struct Books
      { char title[50];
        char author[50];
        char subject[100];
         int book_id;
       } book;
     Accessing Structure Members
• To access any member of a structure, we use
  the member access operator (.). The member
  access operator is coded as a period between
  the structure variable name and the structure
  member that we wish to access. You would
  use the keyword struct to define variables of
  structure type.
                    Union
• A union is a special data type available in C
  that allows to store different data types in the
  same memory location. You can define a
  union with many members, but only one
  member can contain a value at any given time.
  Unions provide an efficient way of using the
  same memory location for multiple-purpose.
                      Defining a Union
union [union tag]
{
member definition;
 member definition;
 ...
 member definition;
 } [one or more union variables];
The union tag is optional and each member definition is a normal
variable definition, such as int i; or float f; or any other valid variable
definition. At the end of the union's definition, before the final
semicolon, you can specify one or more union variables but it is
optional. Here is the way you would define a union type named Data
having three members i, f, and str
       Accessing Union Members
• To access any member of a union, we use
  the member access operator (.).
        Introduction to Pointers
• Some Cprogramming tasks are performed more
  easily with pointers,and other tasks,such as
  dynamic memory allocation,cannot be performed
  without using pointers. So it becomes necessary
  to learn pointers to become a perfect
  Cprogrammer.
• Every variable is a memory location and every
  memory location has its address defined which
  can be accessed using ampersand(&) operator,
  which denotes an address in memory.
           What are Pointers?
• A pointer is a variable whose value is the
  address of another variable,ie., direct address
  of the memory location. Like any variable or
  constant,we must declare a pointer before we
  can use it to store any variable address. Its
  syntax is,
      type *var-name;
          How to use Pointers?
• First we define a pointer variable
• Second assign the address of a variable to a
  pointer
• Finally access the value at the address available
  in the pointer variable.
      This is done by using unary operator * that
returns the value of the variable located at the
address specified by its operand.
                 Pointer arithmetic
• A pointer in c is an address, which is a numeric value. Therefore,
  you can perform arithmetic operations on a pointer just as you can
  on a numeric value. There are four arithmetic operators that can be
  used on pointers: ++, --, +, and -
• To understand pointer arithmetic, let us consider that ptr is an
  integer pointer which points to the address 1000. Assuming 32-bit
  integers, let us perform the following arithmetic operation on the
  pointer- ptr++
• After the above operation, the ptr will point to the location 1004
  because each time ptr is incremented, it will point to the next
  integer location which is 4 bytes next to the current location. This
  operation will move the pointer to the next memory location
  without impacting the actual value at the memory location.
  If ptr points to a character whose address is 1000, then the above
  operation will point to the location 1001 because the next character
  will be available at 1001.
Incrementing a Pointer
Decrementing a Pointer
          Pointer Comparisons
• Pointers may be compared by using relational
  operators, such as ==, <, and >. If p1 and p2
  point to variables that are related to each
  other, such as elements of the same array,
  then p1 and p2 can be meaningfully
  compared.
Array of Pointers
            Pointer to Pointer
• A pointer to a pointer is a form of multiple
  indirection, or a chain of pointers. Normally, a
  pointer contains the address of a variable.
  When we define a pointer to a pointer, the
  first pointer contains the address of the
  second pointer, which points to the location
  that contains the actual value as shown below.
                          Void pointers
• Suppose we have to declare integer pointer,character pointer and float
    pointer then we need to declare 3 pointer variables.
• Instead of declaring different types of pointer variable it is feasible to
    declare single pointer variable which can act as integer pointer,character
    pointer
• In C General Purpose Pointer is called as void Pointer.
• It does not have any data type associated with it
• It can store address of any type of variable
• A void pointer is a C convention for a raw address.
• A void pointer is a pointer that has no associated data type with it. A void
    pointer can hold address of any type and can be typcasted to any type.
int a = 10;
char b = 'x';
void *p = &a; // void pointer holds address of int 'a'
p = &b; // void pointer holds address of char 'b‘
malloc() and calloc() return void * type and this allows these functions to be
used to allocate memory of any data type (just because of void *)
                       Files
• A file represents a sequence of bytes,
  regardless of it being a text file or a binary file.
  C programming language provides access on
  high level functions as well as low level (OS
  level) calls to handle file on your storage
  devices.
                 Opening Files
• You can use the fopen( ) function to create a new
  file or to open an existing file. This call will
  initialize an object of the type FILE, which
  contains all the information necessary to control
  the stream.
• Syntax is, FILE *fopen( const char * filename,
  const char * mode );
• Here, filename is a string literal, which you will
  use to name your file, and access mode can have
  one of the following values −
                           Opening files
Sr.No.   Mode & Description
1        r Opens an existing text file for reading purpose.
2        w Opens a text file for writing. If it does not exist, then a new file is created.
         Here your program will start writing content from the beginning of the file.
3        a Opens a text file for writing in appending mode. If it does not exist, then a
         new file is created. Here your program will start appending content in the
         existing file content.
4        r+ Opens a text file for both reading and writing.
5        w+ Opens a text file for both reading and writing. It first truncates the file to
         zero length if it exists, otherwise creates a file if it does not exist.
6        a+ Opens a text file for both reading and writing. It creates the file if it does
         not exist. The reading will start from the beginning but writing can only be
         appended.
                   Closing a File
• To close a file, use the fclose( ) function.
• Syntax is int fclose( FILE *fp );
• The fclose(-) function returns zero on success, or EOF if
  there is an error in closing the file. This function
  actually flushes any data still pending in the buffer to
  the file, closes the file, and releases any memory used
  for the file. The EOF is a constant defined in the header
  file stdio.h.
• There are various functions provided by C standard
  library to read and write a file, character by character,
  or in the form of a fixed length string.
                    Writing a File
• Syntax is, int fputc( int c, FILE *fp );
• The function fputc() writes the character value of the
  argument c to the output stream referenced by fp. It
  returns the written character written on success
  otherwise EOF if there is an error. You can use the following
  functions to write a null-terminated string to a stream −
• int fputs( const char *s, FILE *fp ); The
  function fputs() writes the string s to the output stream
  referenced by fp. It returns a non-negative value on
  success, otherwise EOF is returned in case of any error. You
  can use int fprintf(FILE *fp,const char *format, ...)function
  as well to write a string into a file.
                  Writing a file
• #include <stdio.h>
   void main()
   { FILE *fp;
    fp = fopen("/tmp/test.txt", "w+");
    fprintf(fp, "This is testing for fprintf...\n");
fputs("This is testing for fputs...\n", fp);
fclose(fp);
 }
                       Reading a File
• int fgetc( FILE * fp ); The fgetc() function reads a character from the
  input file referenced by fp. The return value is the character read, or
  in case of any error, it returns EOF. The following function allows to
  read a string from a stream −
• char *fgets( char *buf, int n, FILE *fp ); The functions fgets() reads
  up to n-1 characters from the input stream referenced by fp. It
  copies the read string into the buffer buf, appending
  a null character to terminate the string.
• If this function encounters a newline character '\n' or the end of the
  file EOF before they have read the maximum number of characters,
  then it returns only the characters read up to that point including
  the new line character. You can also use int fscanf(FILE *fp, const
  char *format, ...) function to read strings from a file, but it stops
  reading after encountering the first space character.
                              Reading a file
•      #include <stdio.h>
    void main()
    {
     FILE *fp;
     char buff[255];
     fp = fopen("/tmp/test.txt", "r");
     fscanf(fp, "%s", buff);
     printf("1 : %s\n", buff );
     fgets(buff, 255, (FILE*)fp);
     printf("2: %s\n", buff );
     fgets(buff, 255, (FILE*)fp);
      printf("3: %s\n", buff );
      fclose(fp);
       getch();
     }
                Reading a file
• First, fscanf() read just This because after that,
  it encountered a space, second call is
  for fgets()which reads the remaining line till it
  encountered end of line. Finally, the last
  call fgets() reads the second line completely.
            C - Command Line Arguments
•    In C it is possible to accept command line arguments. Command-line arguments are given after the
     name of a program in command-line operating systems like DOS or Linux, and are passed in to the
     program from the operating system
• main() function of a C program accepts arguments from command line or from other shell scripts
     by following commands. They are,
   argc
   argv[]
   where,
   argc – Number of arguments in the command line including program name
   argv[] – This is carrying all the arguments
• In real time application, it will happen to pass arguments to the main program itself. These
     arguments are passed to the main () function while executing binary file from command line.
• For example, when we compile a program (test.c), we get executable file in the name “test”.
• Now, we run the executable “test” along with 4 arguments in command line like below.
      ./test this is a program
Where,
argc          =    5
argv[0]        =    “test”
argv[1]        =    “this”
argv[2]        =    “is”
argv[3]        =    “a”
argv[4]        =    “program”
argv[5]        =    NULL
                 Command line argument
#include <stdio.h>
#include <stdlib.h>
int main(int argc, char *argv[]) // command line arguments
{
if(argc!=5)
{
  printf("Arguments passed through command line " \
       "not equal to 5");
  return 1;
}
  printf("\n Program name : %s \n", argv[0]);
 printf("1st arg : %s \n", argv[1]);
printf("2nd arg : %s \n", argv[2]);
printf("3rd arg : %s \n", argv[3]);
  printf("4th arg : %s \n", argv[4]);
 printf("5th arg : %s \n", argv[5]);
 return 0;
}
 OUTPUT:
Program name : test
1st arg : this
2nd arg : is
3rd arg : a
4th arg : program
5th arg : (null)
       Dynamic memory allocation
• It is a process of allocating or de-allocating the memory at run time
  it is called as dynamically memory allocation.
• When we are working with array or string static memory allocation
  will be take place that is compile time memory management.
• When we ate allocating the memory at compile we cannot extend
  the memory at run time, if it is not sufficient.
• By using compile time memory management we cannot utilize the
  memory properly
• In implementation when we need to utilize the memory more
  efficiently then go for dynamic memory allocation.
• By using dynamic memory allocation whenever we want which type
  we want or how much we type that time and size and that we much
  create dynamically.
                     Malloc()
• By using malloc() we can create the memory
  dynamically at initial stage. Malloc() required one
  argument of type size type that is data type size
  malloc() will creates the memory in bytes format.
  Malloc() through created memory initial value is
  garbage
  Syntax: Void*malloc(size type);
  int *ptr; ptr=(int*)malloc(sizeof (int)); //2 byte
long double*ldptr; ldptr=(long
double*)malloc(sizeof(long double)) // 2 byte
char*cptr; cptr=(char*)malloc(sizeof(char)); //1
byte int*arr; arr=(int*)malloc(sizeof int()*10); //20
byte cahr*str; str=(char*)malloc(sizeof(char)*50);
//50 byte
                      calloc()
• By using calloc() we can create the memory
  dynamically at initial stage.
• calloc() required 2 arguments of type count, size-
  type.
• Count will provide number of elements; size-type
  is data type size.
• calloc() will creates the memory in blocks format.
• Initial value of the memory is zero.
Syntax
int*arr; arr=(int*)calloc(10, sizeof(int)); // 20 byte
cahr*str; str=(char*)calloc(50, siceof(char)); // 50
byte
         What is Data Structure?
• In computer terms, a data structure is a
  Specific way to store and organize data in a
  computer’s memory so that these data can be
  used efficiently later. Data may be arranged in
  many different ways such as the logical or
  mathematical model for a particular
  organization of data is termed as a data
  structure.
Difference Between Malloc and Calloc
malloc                                  calloc
                                        •   The name calloc stands for contiguous
• The name malloc stands                    allocation.
  for memory allocation.                •   void *calloc(size_t n, size_t size)returns
• void *malloc(size_t n) returns a          a pointer to enough free space for an
                                            array of n objects of the specified size,
  pointer to n bytes of uninitialized       or NULL if the request cannot be
  storage, or NULL if the request           satisfied. The storage is initialized to
  cannot be satisfied. If the space         zero.
  assigned by malloc() is overrun,      •   calloc() take two arguments those
                                            are: number of blocks and size of each
  the results are undefined.                block.
• malloc() takes one argument that      •   syntax of calloc():
  is, number of bytes.                  •   void *calloc(size_t n, size_t size);
• syntax of malloc():                   •   Allocates a contiguous block of memory
                                            large enough to hold n elements
• void *malloc(size_t n);                   of sizebytes each. The allocated region
                                            is initialized to zero.
• Allocates n bytes of memory. If       •   calloc takes little longer
  the allocation succeeds, a void           than mallocbecause of the extra step of
  pointer to the allocated memory           initializing the allocated memory by
  is returned. Otherwise NULL is            zero. However, in practice the
                                            difference in speed is very tiny and not
  returned.                                 recognizable.
• malloc is faster than calloc.
                        realloc()
• By using realloc() we can create the memory
   dynamically at middle stage.
• Generally by using realloc() we can reallocation the
   memory.
• Realloc() required 2 arguments of type void*,
   size_type.
• Void* will indicates previous block base address, size-
   type is data type size.
• Realloc() will creates the memory in bytes format and
   initial value is garbage.
Syntax
void*realloc(void*, size-type); int *arr; arr=(int*)calloc(5,
sizeof(int)); ..... ........ ....
arr=(int*)realloc(arr,sizeof(int)*10);
                         free()
• When we are working with dynamic memory allocation
    memory will created in heap area of data segment.
• When we are working with dynamic memory allocation
    related memory it is a permanent memory if we are
    not de-allocated that's why when we are working with
    dynamic memory allocation related program, then
    always recommended to deleted the memory at the
    end of the program.
• By using free(0 dynamic allocation memory can be de-
    allocated.
• free() requires one arguments of type void*.
Syntax
void free(voie*); int *arr; arr=(int*)calloc(10,sizeof(int));
... ...... free(arr);
      Categories of Data Structure
The data structure can be sub divided into major
types:
• Linear Data Structure
• Non-linear Data Structure
                  Linked list
• Linked list is a special type of data structure
  where all data elements are linked to one
  another. Linked list is the collection of nodes
  and every nodes contains two parts data part
  and address part.
    Linked list
•
             Advantages of linked list
• Linked List is Dynamic data Structure.
• You can change size of Linked List during program run time.
• Insertion and Deletion Operations are Easier, you can insert any node at
  any place and also delete any node easily..
• No memory wastage ,i.e no need to pre-allocate memory
• Faster Access time,can be expanded in constant time without memory
  overhead
• You can easily implement Linear Data Structures such as Stack,Queue
  using Linked list
• Dynamic Data Structure: The size of linked list increase and decrease
  during program execution.
• No memory wastage: In linked list memory will be allocated at the time of
  program execution so no memory wastage.
• Easily insert and delete data: In linked list you can insert any data at
  specific position and also delete any data from specific position.
      Dis-Advantages of linked list
• Need more memory: For store data in linked
  list you need more memory space, you need
  memory space for both data and address part.
                     Create Linked list
#include<stdio.h>
#include<stdlib.h>
struct Node
{
  int data;
  struct Node *next;
};
// This function prints contents of linked list starting from
// the given node
void printList(struct Node *n)
{
  while (n != NULL)
  {
     printf(" %d ", n->data);
     n = n->next;
  }
}
                               Create Linked List
void main()
{
  struct Node* head = NULL;
  struct Node* second = NULL;
  struct Node* third = NULL;
    // allocate 3 nodes in the heap
    head = (struct Node*)malloc(sizeof(struct Node));
    second = (struct Node*)malloc(sizeof(struct Node));
    third = (struct Node*)malloc(sizeof(struct Node));
    head->data = 1; //assign data in first node
    head->next = second; // Link first node with second
    second->data = 2; //assign data to second node
    second->next = third;
    third->data = 3; //assign data to third node
    third->next = NULL;
    printList(head);
    getch();
}
                                  Insertion
#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
typedef struct node
{
  int data;
  struct node* next;
}node;
struct node* head;
void insert(int x)
{
  struct node* temp=head;
  temp=(node*)malloc(sizeof(struct node));
  temp->data=x;
  if(head==NULL)
  {
     temp->next=NULL;
     head=temp;
  }
                                               Insertion
 else
   {
       struct node* temp2=NULL;
       temp2=(node *)malloc(sizeof(struct node));
       temp=head;
       while(temp->next!=NULL)
       {
          temp=temp->next;
        }
       temp->next=temp2;
       temp2->data=x;
       temp2->next=NULL;
      }
     }
void print()
{
   struct node* temp=head;
   while(temp!=NULL)
   {
       printf("%d",temp->data);
       printf(":");
       temp=temp->next;
   }
}
int count()
{
   struct node* temp=NULL;
   int count=0;
                                             Insertion
   while(temp!=NULL)
  {
    count++;
    temp=temp->next;
  }
  return count;
}
void insertAtNth(int value,int pos)
{
  struct node* temp=NULL;
  temp=(node*)malloc(sizeof(struct node));
  if(pos==1)
  {
     temp->data=value;
     temp->next=head;
     head=temp;
     return;
  }
  else
  {
     struct node* temp2=head;
           struct node* temp3=NULL;
     int i=0;
     for(i=1;i<pos-1;i++)
     {
        //temp=temp1;
        temp2=temp2->next;
       temp3=temp2->next;
     }
     temp2->next=temp;
     temp->data=value;
     temp->next=temp3;
     //temp->next=temp2->next;
  }
     printf(" After insertion ");
  print();
  }
                       Insertion
void main()
{
  insert(4);
  insert(8);
  insert(12);
  insert(16);
  insert(20);
  print();
  insertAtNth(24,1);
  insertAtNth(45,3);
  getch();
}
                            Deletion
#include <stdio.h>
#include <stdlib.h>
struct Node
{
       int data;
       struct Node *next;
};
void push(struct Node** head_ref, int new_data)
{
   struct Node* new_node = (struct Node*) malloc(sizeof(struct Node));
   new_node->data = new_data;
   new_node->next = (*head_ref);
   (*head_ref) = new_node;
}
void deleteNode(struct Node **head_ref, int position)
{
  // If linked list is empty
  if (*head_ref == NULL)
     return;
                                       Deletion
// Store head node
 struct Node* temp = *head_ref;
  // If head needs to be removed
  if (position == 0)
  {
     *head_ref = temp->next; // Change head
     free(temp);           // free old head
     return;
  }
// Find previous node of the node to be deleted
  for (int i=0; temp!=NULL && i<position-1; i++)
      temp = temp->next;
   // If position is more than number of ndoes
  if (temp == NULL || temp->next == NULL)
      return;
  // Node temp->next is the node to be deleted
  // Store pointer to the next of node to be deleted
  struct Node *next = temp->next->next;
                                                Deletion
 // Unlink the node from linked list
   free(temp->next); // Free memory
   temp->next = next; // Unlink the deleted node from list
}
 // This function prints contents of linked list starting from
// the given node
void printList(struct Node *node)
{
   while (node != NULL)
   {
      printf(" %d ", node->data);
      node = node->next;
   }
}
/* Drier program to test above functions*/
int main()
{
   /* Start with the empty list */
   struct Node* head = NULL;
push(&head, 7);
   push(&head, 1);
   push(&head, 3);
                          Deletion
    push(&head, 2);
     push(&head, 8);
     puts("Created Linked List: ");
     printList(head);
     deleteNode(&head, 4);
     puts("\nLinked List after Deletion at position 4: ");
     printList(head);
     return 0;
}