Showing posts with label c programming. Show all posts
Showing posts with label c programming. Show all posts

Wednesday, June 24, 2015

C Programming: Pitfalls while word counting

In Earlier post "Count number of characters, words and lines in input", we have seen how to count number of characters,words and lines. Today, we will learn about pitfalls during word counting.

In K&R, we have a separate exercise for this. Exercise 1.14 states "How would you test the word count program? What kinds of input are most likely to uncover bugs if there are any?"

While writing this program earlier, we never handled much cases. There are caveats which needs to be identified and addressed.

First lets list what all possible checks we usually need while word counting.

1. Checking for very short words.
2. Check for very lengthy words.
3. Check for words which separated when new line is encountered. For example kernel
trap. Where kernel is at end of a line and trap follows in next line.4. Considering words like "isn't", "tour's" as single words
5. Check overall files size for size less than 2GB.
6. Check for mistyped words like "kernel  -  trap" which contain spaces in middle or an - instead of space ex.kernel-trap.
7. Check of non ASCII characters
8. Check for different encoding

Please shed your thoughts if I have missing any checks.

Monday, June 1, 2015

C Program : Count number of characters, words and lines in input

Earlier, we have seen "C : Program to display tabs , backspaces visible in an unambiguous way", today we will write a small C program which counts number of characters ,  number of words and number of lines.

Program looks easy when they ask to count lines and numbers but how about words.

If input to stdin is character by character, then we can count characters easily. Also using '\n' , we can identify that line has encountered. Only problem is counting words.

So, we will use a mechanism to find if word has encountered. Lets introduce two states IN and OUT which states currently process word and the other says its out of word respectively.

 #include  
   
 #define IN 1  
 #define OUT 0  
   
 int main()  
 {  
   int c, nl, nw, nc, state;  
   
   state = OUT;  
   nl = nw = nc = 0;  
   
   while((c = getchar()) != EOF)  
   {  
     /* Increment number of characters */  
     ++nc;  
   
     /* Increment number of lines if end of line is encountered */  
     if( c == '\n' )  
     {  
       ++nl;  
     }  
     /* Anything other than character, mark it new word */  
     if( c == ' ' || c == '\n' || c == '\t' )  
     {  
       state = OUT;   /* Its just completed processing a word */
     } /* if new word, increment word count */  
     else if ( state == OUT )  
     {  
       state = IN;  
       ++nw;  
     }  
   }  
   printf(" Number of Characters = %d \n",nc);  
   printf(" Number of lines = %d \n",nl);  
   printf(" Number of Words = %d \n",nw);  
   return 0;  
 }  
   

Output of this program

 mrtechpathi@mrtechpathi:~/Study/C/K_and_R$ ./a.out   
 This program counts  
 number of characters  
 number of words  
 number of lines  
  Number of Characters = 73   
  Number of lines = 4   
  Number of Words = 12   

In this program

  • We read input character by character 
  • First we increment the character (nc)
  • We then check if it is a new line. If new line, we increment the character
  • Now to increment word (collection of characters), we need to do multiple checks which signify end of word. 
  • If its new line or tab or space, we consider that as word and increment word
  • Finally when you press Ctrl+D (in Linux), the program will display the number of characters, number of lines and number of words.
Hope this helped :)


Monday, May 25, 2015

C : Program to display tabs , backspaces visible in an unambiguous way

In my earlier post, we have seen "C : Program to replace multiples spaces with a single space" , today lets modify the same code to display tabs, backspaces.

Below is the program which does this job.
 #include   
 int main()  
 {  
   char c;  
   printf("Enter a line to display tabs \n");  
   while((c=getchar()) != '\n')  
   {  
     if(c == '\t')  
     {  
         putchar('\\');  
         putchar('t');  
     }  
     putchar(c);  
   }  
   printf("\n");  
   return 0;  
 }  
In above program,
  • We read input character by character
  • Check if its tab (\t). If tab, we output (\\) followed by (t) character which displays \t.
  • If its not tab, we simply output the character.
Output of this program,
 mrtechpathi@mrtechpathi:~/Study/C/K_and_R$ ./a.out   
 Enter a line to display tabs   
 This  program     displays     the tabs     entered  
 This \t     program\t     displays\t     the tabs\t     entered  

Monday, May 18, 2015

C : How to print line numbers and function names while debugging C programs

While debugging C program, we often add printf's to print some values or just a debug print. It would be additional advantage if you can print line number and function name when the program is too big to debug. If you are dealing with multiple files, its good idea to print the file name when you use printf isn't ?

In C, there are few preprocessor macros which allow you to print line numbers, function names and files names.

__LINE__           : Prints line number
__FUNCTION__: Prints function number
__FILE__            : Prints file number

These are predefined macros and part of the C/C++ standard. During preprocessing, they are replaced respectively by a constant string holding an integer representing the current line number and by the current file name.
 #include <stdio.h>  
   
 int main()  
 {  
   printf("\n This program prints line number %d\n",__LINE__);  
   printf("\n This program prints function name %s() \n",__FUNCTION__);  
   printf("\n This program prints file name %s\n",__FILE__);  
   return 0;  
 }  

Output of this program:
 mrtechpathi@mrtechpathi:~/Study/C/K_and_R$ ./a.out   
   
  This program prints line number 5  
   
  This program prints function name main()   
   
  This program prints file name print_line_function_file_name.c  
   

Others preprocessor variables :

__func__ : function name (this is part of C99, not all C++ compilers support it)
__DATE__ : a string of form "Mmm dd yyyy"
__TIME__ : a string of form "hh:mm:ss"

C : Program to count spaces and tabs

In earlier post "Character counting in C", we have written a program to count number of characters, lets extend this further and count blanks, tabs and newlines.
 int main()   
 {   
   double char_count;   
   char input_char;   
   int tabs_count=0,spaces_count=0;   
   char input_val;   
    
   printf("\n Input a line to count spaces and tabs \n");   
    
   /* Reading a character */   
   input_char = getchar();   
    
   /* In a for loop read characters till end of line is encountered */   
   for(char_count = 0; input_char != '\n'; ++char_count)   
   {   
     /* Check if input character is a space */     
     if(input_char == ' ')   
     {   
       /* if space, increment space variable count */          
       ++spaces_count;     
     }      
     /* else if input character is a tab */   
     else if(input_char == '\t')   
     {   
       /* if tab increment tab count */             
       ++tabs_count;      
     }   
     /* Read next character to check if its space or tab */   
     input_char = getchar();       
   }   
    
   /* Finally print number of spaces and tabs read */   
   printf("\n Your input contains %d spaces, %d tabs \n",spaces_count,tabs_count);   
    
   return 0;    
 }  
   
In above program,
  • We read a character
  • In a for loop till end of line is encountered, we check each character entered is a space (' ') or tab('\t').
  • Increment spaces_count and tabs_count variables accordingly
  • Finally when new line is encountered, we print the space count and tab count.
Output of this program :
 mrtechpathi@mrtechpathi:~/Study/C/K_and_R$ ./a.out   
   
  Input a line to count spaces and tabs   
 will be giving a tab now     just one tab behind  
   
  Your input contains 9 spaces, 1 tabs  

Thursday, May 14, 2015

Character counting in C using for loop !!!

Yesterday we learnt about "Character Counting in C"  using while loop. Today in order to illustrate the same character counting in C, we will trying using for loop. We will also try to use float or double datatype to store the character count.

Lets get started ....
 #include <stdio.h>  
 int main()  
 {  
   double char_count;  
   printf("\n Input characters to count \n");  
   for(char_count = 0; getchar() != '\n'; ++char_count);  
   printf("\n You have typed %.0f character :) \n",char_count);  
   return 0;  
 }  

Above program,

  • Declares char_count as doube instead of int to make sure that the count is not overflow while taking the input. double takes relatively more time to overflow than int.
  • Requests user to input characters
  • Reads character by character using getchar() till end of the line
  • As you can see, there is no body for for loop here because whole operation of character counting is done in for loop itself. This is the beauty of for loop.
  • for loop and while loop they check the condition first and enter their body to execute the code which provides the programmer more flexibility of programming.
  • Once a line is entered, program exits by printing the character count.
  • One important thing to note here while printing is "%.0f",  usually printf uses %f for printing float or double. Since char_count is decalared as double, we use "%.0f" to supress the decimal point  and fraction part which is zero.
Now output of this program is..
 mrtechpathi@mrtechpathi:~/Study/C/K_and_R$ ./a.out   
  Input characters to count   
 This is single line of input  
  You have typed 28 character :)   


It's very simple but very useful snippet while coding !!

Wednesday, May 13, 2015

About EOF (End of file) in C

Have you ever wondered what is EOF in "Exiting c program right after reading one line or after carriage return while reading input from stdin".

EOF (End of the file) is a macro which expands to an integer constant expression with type int and an implementation dependent negative value but is very commonly -1.

Below is a small snippet to print EOF in c.
 #include <stdio .h="">  
 int main()  
 {  
 printf("\n Value of EOF is %d\n",EOF);  
 return 0;  
 }  

Output of this program is:

 mrtechpathi@mrtechpathi:~/Study/C/K_and_R$ ./a.out   
  Value of EOF is -1  

Exiting c program right after reading one line or after carriage return while reading input from stdin

Yesterday, we learnt about "C program that copies its input to its output one character at a time" , if you observe the program mentioned in this post, you will observe that we are taking the input from stdin (standard input) and outputting to stdout (each line) till EOF (End of the file) is reached.

Ideally stdin EOF is like forever. So, we end up pressing Ctrl+C to exit the program. Now to modify this program to exit right after one line or after a carriage return, we need to do a simple modification.
Replace EOF with '\n'. Yes its as simple as that.

 #include <stdio.h>  
 int main()  
 {  
   int c;  
   printf("Program exits after new line or carriage return \n");  
   printf("Start your input \n");  
   c = getchar();  
   while(c != '\n')  
   {  
     putchar(c);  
     c = getchar();  
   }  
 }  

Only difference you observe is in the while condition, "while(c != EOF) is changed to while(c != '\n')".

Output will be as below.

 mrtechpathi@mrtechpathi:~/Study/C/K_and_R$ ./a.out   
 Enter Ctrl+C is to exit  
 Start your input   
 just one line input  
 just one line input  
Hope you understood this simple concept !!!

Tuesday, May 12, 2015

C program that copies its input to its output one character at a time

I have been blogging few interesting how-to articles which I learn in my daily professional life. Its been a while I haven't blogged any.So, thought of just adding atleast a program per day (very challenging isn't ?) along with how-to articles.

I will start with C-programming. As everyone know "Kernighan & Ritchie" (K&R) is the best book to learn C programming. I will using examples in this book.


If you want any C snippet meanwhile, just drop me a comment will try and get it done for you.  I cant promise, but will try my best to do code for you.


Frist lets start with "C program that copies its input to its output one character at a time"


 #include <stdio.h>  
 int main()  
 {  
   int c;  
   printf("Enter Ctrl+C is to exit\n");  
   printf("Start your input \n");  
   c = getchar();  
   while(c != EOF)  
   {  
     putchar(c);  
     c = getchar();  
   }  
 }  

Above program is exact copy of a program in K&R, I have just added two printf statements to it.

When you compile and run this program, it accepts whatever the character you input from the keyboard and print them once you press enter (new line / carriage return).

It does this task forever because we have used "While( c != EOF )" in our above code snippet.
This while statements will be true till you reach EOF of stdin (standard input) which is forever.

So, in order to exit from running your program, you need to press "Ctrl+C" on your keyboard together.

Now lets run and see, output will be as below
 mrtechpathi@mrtechpathi:~/Study/C/K_and_R$ ./a.out   
 Enter Ctrl+C is to exit  
 Start your input   
 we are  
 we are  
 trying to print  
 trying to print  
 character by character  
 character by character  
 ^C  
Hope you learnt something new :).