Advertisement
deushiro

Untitled

Feb 24th, 2020
267
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.61 KB | None | 0 0
  1. #include <cmath>
  2. #include <iostream>
  3. #include <vector>
  4. #include <algorithm>
  5. #include <string>
  6. #include <set>
  7. #include <map>
  8. #include <list>
  9. #include <time.h>
  10. #include <math.h>
  11. #include <random>
  12. #include <deque>
  13. #include <queue>
  14. #include <cassert>
  15. #include <unordered_map>
  16. #include <unordered_set>
  17. #include <iomanip>
  18. #include <bitset>
  19. #include <sstream>
  20. #include <chrono>
  21. #include <cstring>
  22.  
  23. using namespace std;
  24.  
  25. #define X first
  26. #define Y second
  27. #define pb push_back
  28. #define mp make_pair
  29. #define sz(x) ((int)(x).size())
  30. #define all(x) (x).begin(),(x).end()
  31. #define PI 3.14159265358979323846
  32.  
  33. typedef long long ll;
  34.  
  35. const int maxn = 5e5 + 228;
  36.  
  37. int n;
  38.  
  39.  
  40. int main() {
  41.     ios_base::sync_with_stdio(false);
  42.     cin.tie(0);
  43.     cout.tie(0);
  44.     int tt;
  45.     cin >> tt;
  46.     while(tt--){
  47.         int n, m;
  48.         cin >> n >> m;
  49.         vector<int> ans(26);
  50.         vector<vector<int>> dp(n, vector<int>(26));
  51.         string s;
  52.         cin >> s;
  53.         vector<int> p(m);
  54.         for(int i = 0; i < m; ++i){
  55.             cin >> p[i];
  56.             p[i]--;
  57.         }
  58.         p.push_back(n - 1);
  59.         sort(p.begin(), p.end());
  60.         dp[0][s[0] - 'a'] = 1;
  61.         for(int i = 1; i < sz(s); ++i){
  62.             for(int j = 0; j < 26; ++j){
  63.                 dp[i][j] = dp[i - 1][j];
  64.             }
  65.             dp[i][s[i] - 'a']++;
  66.         }
  67.         for(int t : p){
  68.             for(int j = 0; j < 26; ++j){
  69.                 ans[j] += dp[t][j];
  70.             }
  71.         }
  72.         for(int i = 0; i < 26; ++i){
  73.             cout << ans[i] << " ";
  74.         }
  75.         cout << endl;
  76.     }
  77.    
  78. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement