#include <bits/stdc++.h>
using namespace std;
#define int long long int
#define double long double
#define print(a) for(auto x : a) cout << x << " "; cout << endl
const int M = 1000000007;
const int N = 3e5+9;
const int INF = 2e9+1;
const int LINF = 2000000000000000001;
inline int power(int a, int b) {
int x = 1;
a %= M;
while (b) {
if (b & 1) x = (x * a) % M;
a = (a * a) % M;
b >>= 1;
}
return x;
}
//_ ***************************** START Below *******************************
string a;
int consistency(int n, int k){
int l = (k-1)/2;
int r = k/2;
int ans = 0;
int rows = n/k;
while(l>=0 && r<k){
vector<int> leftCol(26, 0);
for(int i=l; i<n; i+=k){
leftCol[a[i]-'a']++;
}
vector<int> rightCol(26, 0);
for(int j=r; j<n; j+=k){
rightCol[a[j]-'a']++;
}
int maxiF = 0;
for(int i=0; i<26; i++){
int targetF = leftCol[i] + rightCol[i];
maxiF = max(maxiF, targetF);
}
int cost = (2*rows - maxiF);
if(l==r) ans += cost/2;
else ans += cost;
l--;
r++;
}
return ans;
}
int practice(int n, int k){
return 0;
}
void solve() {
int n, k;
cin>> n >> k;
cin >> a;
cout << consistency(n, k) << endl;
}
int32_t main() {
ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);
int t = 1;
cin >> t;
while (t--) {
solve();
}
return 0;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CiNkZWZpbmUgaW50ICAgICAgICAgICAgICBsb25nIGxvbmcgaW50CiNkZWZpbmUgZG91YmxlICAgICAgICAgICBsb25nIGRvdWJsZQojZGVmaW5lIHByaW50KGEpICAgICAgICAgZm9yKGF1dG8geCA6IGEpIGNvdXQgPDwgeCA8PCAiICI7IGNvdXQgPDwgZW5kbAoKCmNvbnN0IGludCBNID0gMTAwMDAwMDAwNzsKY29uc3QgaW50IE4gPSAzZTUrOTsKY29uc3QgaW50IElORiA9IDJlOSsxOwpjb25zdCBpbnQgTElORiA9IDIwMDAwMDAwMDAwMDAwMDAwMDE7CgppbmxpbmUgaW50IHBvd2VyKGludCBhLCBpbnQgYikgewogICAgaW50IHggPSAxOwogICAgYSAlPSBNOwogICAgd2hpbGUgKGIpIHsKICAgICAgICBpZiAoYiAmIDEpIHggPSAoeCAqIGEpICUgTTsgCiAgICAgICAgYSA9IChhICogYSkgJSBNOwogICAgICAgIGIgPj49IDE7CiAgICB9CiAgICByZXR1cm4geDsKfQoKCi8vXyAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiBTVEFSVCBCZWxvdyAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCgoKCgpzdHJpbmcgYTsKCmludCBjb25zaXN0ZW5jeShpbnQgbiwgaW50IGspewoKICAgIGludCBsID0gKGstMSkvMjsKICAgIGludCByID0gay8yOwoKICAgIGludCBhbnMgPSAwOwoKICAgIGludCByb3dzID0gbi9rOwoKICAgIHdoaWxlKGw+PTAgJiYgcjxrKXsKICAgICAgICB2ZWN0b3I8aW50PiBsZWZ0Q29sKDI2LCAwKTsKICAgICAgICBmb3IoaW50IGk9bDsgaTxuOyBpKz1rKXsKICAgICAgICAgICAgbGVmdENvbFthW2ldLSdhJ10rKzsKICAgICAgICB9CiAgICAgICAgdmVjdG9yPGludD4gcmlnaHRDb2woMjYsIDApOwogICAgICAgIGZvcihpbnQgaj1yOyBqPG47IGorPWspewogICAgICAgICAgICByaWdodENvbFthW2pdLSdhJ10rKzsKICAgICAgICB9CgogICAgICAgIGludCBtYXhpRiA9IDA7CiAgICAgICAgZm9yKGludCBpPTA7IGk8MjY7IGkrKyl7CiAgICAgICAgICAgIGludCB0YXJnZXRGID0gbGVmdENvbFtpXSArIHJpZ2h0Q29sW2ldOwogICAgICAgICAgICBtYXhpRiA9IG1heChtYXhpRiwgdGFyZ2V0Rik7CiAgICAgICAgfQoKICAgICAgICBpbnQgY29zdCA9ICgyKnJvd3MgLSBtYXhpRik7CiAgICAgICAgaWYobD09cikgYW5zICs9IGNvc3QvMjsKICAgICAgICBlbHNlIGFucyArPSBjb3N0OwoKCiAgICAgICAgbC0tOwogICAgICAgIHIrKzsKICAgIH0KCiAgICByZXR1cm4gYW5zOwp9CgoKCgoKCgoKCgoKCgoKCmludCBwcmFjdGljZShpbnQgbiwgaW50IGspewoKCiAgICByZXR1cm4gMDsKfQoKCgoKCnZvaWQgc29sdmUoKSB7CiAgICAKICAgIGludCBuLCBrOwogICAgY2luPj4gbiA+PiBrOwogICAgY2luID4+IGE7CiAgICAKICAgIAogICAgY291dCA8PCBjb25zaXN0ZW5jeShuLCBrKSA8PCBlbmRsOwoKCn0KCgoKCgppbnQzMl90IG1haW4oKSB7CiAgICBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKDApOyBjaW4udGllKDApOyBjb3V0LnRpZSgwKTsKCiAgICBpbnQgdCA9IDE7CiAgICBjaW4gPj4gdDsKICAgIHdoaWxlICh0LS0pIHsKICAgICAgICBzb2x2ZSgpOwogICAgfQoKICAgIHJldHVybiAwOwp9