ID Forgery has been a prevalent issue in the city of Einstakt, especially in bars. You are currently working in a government agency that tries to identify individuals sharing the same ID numbers and perform a formal investigation. Each day, your team travels to two random bars to collect the encoded IDs of each bar patron.
Please read instructions and complete in C++. Show functions. Confused.
data:image/s3,"s3://crabby-images/ea73a/ea73ad81c2833a6d8e6d75fbf715f11297ca7558" alt="Introduction
ID Forgery has been a prevalent issue in the city of Einstakt, especially in bars. You
are currently working in a government agency that tries to identify individuals
sharing the same ID numbers and perform a formal investigation. Each day, your
team travels to two random bars to collect the encoded IDs of each bar patron.
Those with the same ID numbers will be approached and invited for an
interrogation. At the end of each mission, a report with listings of guilty and innocent
individuals will be sent to the senior team members for further processing.
Your task is to write a program to decode the ID numbers, find the decoded ID
duplicates (if there are any), and generate a report with decoded IDs of all the guilty
and innocent individuals.
Assumptions:
• Each input file may contain a maximum of 100 encoded IDs.
• Bar names will always be "Bar1" and “Bar2".
• Each encoded and decoded ID may vary in length (8293, 00087, 49, ...).
• Each encoded ID contains only numbers and parentheses.
• Each encoded ID has m characters, where 1 <= m <= 100
• Two different encoded IDs that map to the same decoded ID number are
considered duplicates. There will only be at most two people who share the
same decoded IDs.
• All ID encodings will always have balanced parentheses.
• There will be no space in each encoded ID.
Rules and Operations
1. To decode each ID, reverse the numbers in each pair of the matching
parentheses, starting from the innermost pair.
2. Find the ID duplicates in both bar locations.
3. In your report, print the decoded IDs of both guilty and innocent
individuals in ascending order. The output format is shown in the
examples below.
Note: You must use stacks and linked lists to implement your solution. All
linked list operations must be implemented using recursion!!! Points will
be deducted for using iterative implementations.
Examples
Example 1:
Input11.txt
Bar1
10(01)
(4321)
Bar2
(20)02
Bar1
(20)21
Bar2
3(021)
(4321)
Output11.txt
Guilty:
1234
// All ID(s) sorted in ascending order
Innocent:
0202
0221
// All ID(s) sorted in ascending order
1010
3120
Command line:
Idecode "input=input11.txt;output3Doutput11.txt" or /decode input=input11.txt
output=output11.txt
Example 2:
Input12.txt
Bar2
10(01)
Bar1
(01)10
Bar2
20(12)
Bar1
2(20)1
(4(23)1)
Bar2
1(432)
Output12.txt
Guilty:
1010
// All ID(s) sorted in ascending order
1234
2021
Command
Idecode "input=input12.txt;output=Doutput12.txt" or ./decode input=input12.txt
output=output12.txt
Example 3:
Input13.txt
Bar2
(75(700)1)3
35(748648)
13(05)6(7(6(83)00)1)
Bar1
4(21)5(37(9600))78
1005(3304)
Bar2
64(42)00587611(47)
(3001)
(78)407
0000000000000526(543)
6(542)1
Output13.txt
Innocent:
1003
62451
87407
0000000000000526345
1700573
// All ID(s) sorted in ascending order
10054033
35846847
135061638007
412596007378
64240058761174
Command line:
Idecode “input=input13.txt;output=Doutput13.txt" or ./decode input=input13.txt
output=output13.txt"
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
void find_duplicates( vector<string> input ) {
int i,j,n = input.size();
map<string,int> m;
for(i=0;i<n;i++)
{
if(input[i]=="Bar1" || input[i]=="Bar2")
continue;
string tmp = input[i];
string ans = "";
for(j=0;j<tmp.length();j++)
{
if(tmp[j]!='(')
{
ans+=tmp[j];
continue;
}
else { j++;
string tt = "";
while(tmp[j]!=')')
{
tt+=tmp[j];
j++;
}
reverse(tt.begin(),tt.end());
ans+=tt;
j++;
m[ans]++;
}
}
}
vector<string> innocent,duplicate;
for(auto ite =m.begin();ite!=m.end();ite++)
{
if(ite->second == 1)
{
innocent.push_back(ite->first);
}
else {
duplicate.push_back(ite->first);
}
}
sort(innocent.begin(),innocent.end());
sort(duplicate.begin(),duplicate.end());
cout<<"Innocent:\n";
for(i=0;i<innocent.size();i++)
cout<<innocent[i]<<"\n";
cout<<"Duplicate\n";
for(i=0;i<duplicate.size();i++)
cout<<duplicate[i]<<"\n";
}
Trending now
This is a popular solution!
Step by step
Solved in 2 steps
data:image/s3,"s3://crabby-images/e0cbe/e0cbe7c1cfa79a285a06530332b315bcf077d9a4" alt="Blurred answer"
data:image/s3,"s3://crabby-images/741da/741da0cea27bfc4afcecba2c359e4bfe1cd520b7" alt="Computer Networking: A Top-Down Approach (7th Edi…"
data:image/s3,"s3://crabby-images/aa558/aa558fb07235ab55e06fe3a3bc3f597042097447" alt="Computer Organization and Design MIPS Edition, Fi…"
data:image/s3,"s3://crabby-images/c6dd9/c6dd9e6795240236e2b28c31c737e700c2dd7df3" alt="Network+ Guide to Networks (MindTap Course List)"
data:image/s3,"s3://crabby-images/741da/741da0cea27bfc4afcecba2c359e4bfe1cd520b7" alt="Computer Networking: A Top-Down Approach (7th Edi…"
data:image/s3,"s3://crabby-images/aa558/aa558fb07235ab55e06fe3a3bc3f597042097447" alt="Computer Organization and Design MIPS Edition, Fi…"
data:image/s3,"s3://crabby-images/c6dd9/c6dd9e6795240236e2b28c31c737e700c2dd7df3" alt="Network+ Guide to Networks (MindTap Course List)"
data:image/s3,"s3://crabby-images/7daab/7daab2e89d2827b6568a3205a22fcec2da31a567" alt="Concepts of Database Management"
data:image/s3,"s3://crabby-images/cd999/cd999b5a0472541a1bb53dbdb5ada535ed799291" alt="Prelude to Programming"
data:image/s3,"s3://crabby-images/39e23/39e239a275aed535da3161bba64f5416fbed6c8c" alt="Sc Business Data Communications and Networking, T…"