CodeChef SEPT17 Chef and Pick Digit (code: CHEFPDIG)

Problem: Little Chef and Sum 

https://www.codechef.com/SEPT17/problems/CHEFPDIG

Chef likes to play with big numbers. Today, he has a big positive integer N. He can select any two digits from this number (the digits can be same but their positions should be different) and orders them in any one of the two possible ways. For each of these ways, he creates a two digit number from it (might contain leading zeros). Then, he will pick a character corresponding to the ASCII value equal to this number, i.e. the number 65 corresponds to 'A', 66 to 'B' and so on till 90 for 'Z'. Chef is only interested in finding which of the characters in the range 'A' to 'Z' can possibly be picked this way. Input 
The first line of the input contains an integer T denoting the number of test cases.
The first line of the input contains an integer N.


Output 
For each test case, output a string containing characters Chef can pick in sorted order If the resulting size of string is zero, you should output a new line.

Constraints :


  • 1T10
  • 1N10100000
Subtask :
 
  • Subtask #1 (40 points) N1010
  • Subtask #2 (60 points) Original Constraints

Example

Input:
4
65
566
11
1623455078

Output:
A
AB

ACDFGHIJKLNPQRSTUVW

Explanation


Example case 1. Chef can pick digits 6 and 5 and create integers 56 and 65. The integer 65 corresponds to 'A'.
Example case 2. Chef can pick digits 6 and 5 and create 'A' as it equals 65. He can pick 6 and 6 (they are picked from position 2 and position 3, respectively) to create 'B' too. Hence answer is "AB".
Example case 3. It's not possible to create any character from 'A' to 'Z'. Hence, we just print a new line.

Solutions :

#include<iostream>
#include<vector>
#include<algorithm>
#include<iterator>
using namespace std;
 
int main()
{
    int t;
    cin>>t;
    while(t--)
    {
        long long unsigned int n,x;
        cin>>n;
        x=n;
        vector<int>nums;
        vector<char>alpha;
        while(x !=0)
        {
            int a = x%10;
            nums.push_back(a);
            x /=10;
        }
        
        int p = nums.size();
        for(int i=0; i<p; i++)
        {
            for(int j=0; j<p ;j++)
            {
                if(j != i)
                {
                    int b = 10*nums[i] + nums[j];
                    char c = b;
                    if(b>=65 && b<=90)
                        alpha.push_back(c);
                    b= 10*nums[j] + nums[i];
                    c= b;
                    if(b>=65 && b<=90)
                        alpha.push_back(c);
                }
            }
        }
        
        sort(alpha.begin(), alpha.end());
        vector<char>::iterator it;
        it = unique(alpha.begin(), alpha.end());
        alpha.resize(distance(alpha.begin(), it));
    for(int i=0; i<alpha.size(); i++)
        cout<<alpha[i];
        cout<<endl;
    }
    
    
    
    return 0;
}
 

Comments

Popular posts from this blog

CodeChef : Breaking Bricks || Problem Code: BRKBKS

HackerRank Problem : Reverse and capitalise first alphabet of each word.

CodeChef (AUG17 LunchTime) : Mathison and pangrams - MATPAN