Write a program to print distinct words in an input
along with their count in input in decreasing order of their
count..
Answer Posted / gururaj l j
Solution
/* This Program counts the distinct words in the input
string preceded each word by its count */
#include <stdio.h>
#include <string.h>
void DistinctWords(char s[ ]);
void main()
{
char s[100];
printf("Enter the String ");
gets(s);
if(strlen(s) <= 0)
printf("Please provide the input
string\n");
else
DistinctWords(s);
}
/* Purpose: This function counts the distinct words in the
input string preceded each word by its count
Input : String
Output : distinct words with its count
*/
void DistinctWords(char s[])
{
char words[50][50];
char distinct[50];
int i, j, l, k = 0, start, end, f = 1, m = 0, n =
0;
int count;
int countindex[20],cindex = 0;
for(l = 0,i = 0; s[i] != ' '; i++, l++)
words[k][i] = s[i];
words[k][i] = '\0';
k++;
start = i+1;
for(i = i+1; s[i]; i++)
{
if(s[i] == ' ')
{
end = i-1;
f = i+1;
for(j = 0, l = start; l <= end;
l++, j++)
words[k][j] = s[l];
words[k][j] = '\0';
k++;
start = i+1;
}
}
for(l = f, i = 0; s[l]; i++, l++)
words[k][i] = s[l];
words[k][i] = '\0';
for(i = 0;i <= k; i++)
{
count = 0;
for(j = i; j <= k; j++)
{
if((stricmp(words[i], words[j])) == 0)
count++;
}
f = 1;
for(j = 0; j < i; j++)
{
if(strcmp(words[i], words[j]) == 0)
{
f = 0;
break;
}
}
if(f == 1)
printf("\n\t%s Occur %d Times\n", words[i],
count);
}
}
Is This Answer Correct ? | 18 Yes | 7 No |
Post New Answer View All Answers
How is a pointer variable declared?
What do you know about the use of bit field?
Is c language still used?
Write a factorial program using C.
What is New modifiers?
How can you avoid including a header more than once?
Why is struct padding needed?
What is strcmp in c?
What language is lisp written in?
What is build process in c?
Is there any data type in c with variable size?
What does do in c?
Explain how can a program be made to print the name of a source file where an error occurs?
How do we open a binary file in Read/Write mode in C?
How can I display a percentage-done indication that updates itself in place, or show one of those twirling baton progress indicators?