Skip to main content

PROGRAMMING FOR PROBLEM SOLVING LAB : Program 40

Write a C program to count the lines, words and characters in a given text.

Algorithm:

 step 1: Start
Step 2: Read the text until an empty line
Step 3: Compare each character with newline char „\n‟ to count no of lines
Step 4: Compare each character with tab char „\t\‟ or space char „ „ to count no of words
Step 5: Compare first character with NULL char „\0‟ to find the end of text 
Step 6: No of characters = length of each line of text
Step 7: Print no of lines, no of words, no of chars 
Step 8: Stop

 

PROGRAM

#include <stdio.h>
int main()
{
    char str[100];//input string with size 100
    int words=0,newline=0,characters=0; // counter variables
    printf("ENTER STRING   AND PRESS ~ \n");
    scanf("%[^~]",&str);//scanf formatting    
    for(int i=0;str[i]!='\0';i++)
     { 
         if(str[i] == ' ')
         { 
              words++;
         }
         else if(str[i] == '\n')
         {
             newline++;
              words++;//since with every next line new words start. 
         }
         else if(str[i] != ' ' && str[i] != '\n')
         {
         characters++;
         }
     }
    if(characters > 0)
    {
        words++;
        newline++;
    }
     printf("Total number of words : %d\n",words);
     printf("Total number of lines : %d\n",newline);
     printf("Total number of characters : %d\n",characters);
    return 0;
}

OUTPUT:


ENTER STRING AND PRESS
hello
this is c
programm~
Total number of words : 5
Total number of lines : 3
Total number of characters : 20

Comments

Post a Comment

Popular posts from this blog

INSERTION SORT, BUBBLE SORT, SELECTION SORT

// C program for insertion sort #include <math.h> #include <stdio.h> void insertionSort(int arr[], int n);     // A utility function to print a sorted array of size n void printArray(int arr[], int n) {     int i;     for (i = 0; i < n; i++)         printf("%d ", arr[i]);     printf("\n"); }    // Driver code int main() {     int arr[15],n,i;         printf("enter number of elements in array \n");     scanf("%d", &n);         printf("enter array values to sort\n");     for(i=0; i<n; i++)     scanf("%d", &arr[i]);         insertionSort(arr, n);     printArray(arr, n);        return 0; } /* Function to sort an array using insertion sort*/ void insertionSort(int arr[], int n) {     int i, key, j;     for (i = 1; i < n; i++) ...

Learning and Development Interview Questions and answers for Mathematics-1.

  1). What is Mean, Mode and Median? Solution Answer: The mean is the average of a  collection of numbers or terms in a sequence. To calculate the mean use a formula is sum of total terms divided  by number of terms. The mode  is the most f requent number or term in a sequence. It means the number that occurred  highest number of times  in a sequence. To find the mode arrange the numbers in ascending or descending order and verify which number repeated most number of times in a sorted sequence. The median is the middle number/term where the sequence is arranged in ascending or descending order. If the sorted sequence have odd number of terms then  divide by 2 and round up to get the position of the median number.  If the  sorted sequence  have  even  number of terms then  divide by 2  to get the position of the median number.  2 ). What is the Difference between Fractional and Rational number? Solu...