CodeChef (AUG17 LunchTime) : Mathison and pangrams - MATPAN
Problem: Mathison and pangrams
Mathison recently inherited an ancient papyrus that contained some text.
Unfortunately, the text was not a pangram. Now, Mathison has a
particular liking for holoalphabetic strings and the text bothers him.
The good news is that Mathison can buy letters from the local store in
order to turn his text into a pangram.
However, each letter has a price and Mathison is not very rich. Can you
help Mathison find the cheapest way to obtain a pangram?
Input
The first line of the input file will contain one
integer, T, representing the number of tests.
Each test will be formed from two lines. The first one contains 26 space-separated integers, representing the prices of all letters. The second will contain Mathison’s initial text (a string of N lowercase letters).
Output
The output file will contain T lines, one for each test. Each line will contain the answer for the corresponding test.
Constraints :
- 1 ≤ T ≤ 10
- 1 ≤ N ≤ 50,000
- All prices are natural numbers between 1 and 1,000,000 (i.e. 106).
- A pangram is a string that contains every letter of the Latin alphabet at least once.
- All purchased letters are added to the end of the string
Subtask :
Subtask #1 (30 points):
- N = 1
Subtask #2 (70 points):
- Original constraints
Example⌗
Input:
2
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
abcdefghijklmopqrstuvwz
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
thequickbrownfoxjumpsoverthelazydog
Output:
63
0
Explanation⌗
First test There are three letters missing from the original string: n (price 14), x (price 24), and y (price 25). Therefore the answer is 14 + 24 + 25 = 63.
Second test No letter is missing so there is no point in buying something. The answer is 0.
Solutions :
*
https://www.codechef.com/problems/MATPAN
*/
#include <iostream>
#include <vector>
using namespace std;
int main()
{
int t;
cin >> t;
while (t--) {
char x = 'a';
vector<char> alpha;
vector<int> cost(26);
for (int i = 1; i <= 25; i++) {
alpha.push_back(x);
x = x + 1;
}
alpha.push_back(x);
//-----------------------------------
for (int i = 0; i < 26; i++)
cin >> cost[i];
string s;
cin >> s;
for (int i = 0; i < s.length(); i++) {
for (int j = 0; j < 26; j++)
if (s[i] == alpha[j] && alpha[j] != '0')
alpha[j] = '0';
}
int sum = 0;
for (int i = 0; i < 26; i++) {
if (alpha[i] != '0')
sum += cost[i];
}
cout << sum << endl;
}
return 0;
}
** **