Algorithm
You have an image file of size 2×2, consisting of 4 pixels. Each pixel can have one of 26 different colors, denoted by lowercase Latin letters.
You want to recolor some of the pixels of the image so that all 4 pixels have the same color. In one move, you can choose no more than two pixels of the same color and paint them into some other color (if you choose two pixels, both should be painted into the same color).
What is the minimum number of moves you have to make in order to fulfill your goal?
The first line contains one integer t (1≤t≤1000) — the number of test cases.
Each test case consists of two lines. Each of these lines contains two lowercase letters of Latin alphabet without any separators, denoting a row of pixels in the image.
For each test case, print one integer — the minimum number of moves you have to make so that all 4 pixels of the image have the same color.
1 2 0 3 1
Let's analyze the test cases of the example.
In the first test case, you can paint the bottom left pixel and the top right pixel (which share the same color) into the color r, so all pixels have this color.
In the second test case, two moves are enough:
- paint both top pixels, which have the same color c, into the color b;
- paint the bottom left pixel into the color b.
In the third test case, all pixels already have the same color.
In the fourth test case, you may leave any of the pixels unchanged, and paint all three other pixels into the color of that pixel in three moves.
In the fifth test case, you can paint both top pixels into the color x.
Code Examples
#1 Code Example with C++ Programming
Code -
C++ Programming
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define endl '\n'
#define debug(n) cout<<(n)<<endl;
const ll INF = 2e18 + 99;
int main(){
ios_base::sync_with_stdio(false);
cin.tie(NULL);
int t;
cin>>t;
while(t--){
unordered_set<char> uos;
string s1, s2;
cin>>s1>>s2;
uos.insert(s1[0]);
uos.insert(s1[1]);
uos.insert(s2[0]);
uos.insert(s2[1]);
cout<<uos.size()-1<<endl;
}
}
Copy The Code &
Try With Live Editor
Input
rb
br
cc
wb
aa
aa
ab
cd
yy
xx
Output
2
0
3
1
Demonstration
Codeforcess Solution 1721-A A. Image ,C++, Java, Js and Python,1721-A,Codeforcess Solution