Wednesday, November 30, 2011

UVA 12289 One-Two-Three Solution

Problem Statement :
Your little brother has just learnt to write one, two and three, in English. He has written a lot of those words in a paper, your task is to recognize them. Note that your little brother is only a child, so he may make small mistakes: for each word, there might be at most one wrong letter. The word length is always correct. It is guaranteed that each letter he wrote is in lower-case, and each word he wrote has a unique interpretation.

Input 

The first line contains the number of words that your little brother has written. Each of the following lines contains a single word with all letters in lower-case. The words satisfy the constraints above: at most one letter might be wrong, but the word length is always correct. There will be at most 10 words in the input.

Output 

For each test case, print the numerical value of the word.

Sample Input 

3
owe
too
theee

Sample Output 

1
2
3
 
Critical Input

7
ont
owe
ene
ono
ewo
tno
twn

Output
1
1
1
1
2
2
2
 
Solution : 
Approach 1:
#include <stdio.h>

/*Time : 0.004s*/
int main(){
 int i,t,len,cnt;
 char str[5],one[]={"one"};

 scanf("%d",&t);
 while(t--){
  scanf("%s",str);
  for( len = 0; str[len]; len++);
  cnt = 0;
  if(len == 5)
   printf("3\n");
  else{
   for( i = 0; i < len; i++){
    if( one[i] == str[i]){
     cnt++;
    }
   }
   if( cnt >= 2)
    printf("1\n");
   else
    printf("2\n");
  }
 }
 return 0;
}

No comments:

Post a Comment