Wednesday, 25 June 2014

Forgot Password-Solution


Problem Statement:

Chef changed the password of his laptop a few days ago, but he can't remember it today. Luckily, he wrote the encrypted password on a piece of paper, along with the rules for decryption.
The encrypted password is a string S consists of ASCII printable characters except space (ASCII 33 - 126, in decimal notation, the same below). Read here for more details: ASCII printable characters.
Each rule contains a pair of characters ci, pi, denoting that every character ci appears in the encrypted password should be replaced with pi. Notice that it is not allowed to do multiple replacements on a single position, see example case 1 for clarification.
After all the character replacements, the string is guaranteed to be a positive decimal number. The shortest notation of this number is the real password. To get the shortest notation, we should delete all the unnecessary leading and trailing zeros. If the number contains only non-zero fractional part, the integral part should be omitted (the shortest notation of "0.5" is ".5"). If the number contains zero fractional part, the decimal point should be omitted as well (the shortest notation of "5.00" is "5").
Please help Chef to find the real password.

Input

The first line of the input contains an interger T denoting the number of test cases.
The description of T test cases follows.
The first line of each test case contains a single interger N, denoting the number of rules.
Each of the next N lines contains two space-separated characters ci and pi,
denoting a rule.
The next line contains a string S, denoting the encrypted password.

Output

For each test case, output a single line containing the real password.

Constraints

  • 1 ≤ T ≤ 1000
  • 0 ≤ N ≤ 94
  • All characters in S and ci may be any ASCII printable character except space. (ASCII 33 - 126)
  • All ci in a single test case are distinct.
  • pi is a digit ("0" - "9") or a decimal point "." (ASCII 46).
  • The total length of S in a single input file will not exceed 106.

Example

Input:
4
2
5 3
3 1
5
0
01800.00
0
0.00100
3
x 0
d 3
# .
0xd21#dd098x

Output:
3
1800
.001
321.33098 
 
 
Solution:
 
/*******************************************************************************************/
 
 
#include<stdio.h>
#include<stdlib.h>
#include<string.h>

int main()
{
 int t,n,i,ch,flag,flag1;
 int j,k,l;
 char ci,pi,*str,*cih;
 scanf("%d",&t);
 cih=(char*)malloc(sizeof(char)*130);
  
 for(i=0;i<t;i++)
 { 
  str=(char*)malloc(sizeof(char)*10000000);
 
  flag=0;
  flag1=0;
  for(j=0;j<130;j++)
   cih[j]=' ';
  scanf("%d",&n);
  for(j=0;j<n;j++)
  {
   scanf(" %c %c",&ci,&pi);
   ch=(int)ci;
   cih[ch]=pi;
  }
  
  scanf("%s",str);
  
  for(j=0;str[j]!='\0';j++)
  {
   if(cih[(int)str[j]]!=' ')
    str[j]=cih[(int)str[j]];
  }
  
  for(j=0;str[j]!='\0';j++)
  {
   if(str[j]=='0' || str[j]=='.')
   { 
   }
   else
   {
    flag1=1;
    break;
   }
  }
  
  if(flag1==1)
  {
   for(j=0;str[j]!='\0';j++)
   {
    if(str[j]!='0')
     break;
   }
  
   for(k=j;str[k]!='\0';k++)
   {
    if(str[k]=='.')
    {
     flag=1;
     break;
    } 
   }
   k=strlen(str)-1;
   if(flag==1)
   {
    for(k=(strlen(str)-1);k>=j;k--)
    {
     if(str[k]!='0')
      break;
    }
    if(str[k]=='.')
     k=k-1;
   }
  
   for(l=j;l<=k;l++)
    printf("%c",str[l]);
   printf("\n");
  }
  else
   printf("0\n"); 
  free(str);
 }
 return 0;
} 


/*************************************************************************************/

No comments:

Post a Comment