#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define all(v) v.begin(),v.end()
#define endl '\n'
#pragma GCC target("popcnt")
#define bug(...) __f (#__VA_ARGS__, __VA_ARGS__);
template <typename Arg1>void __f (const char* name, Arg1&& arg1) {cout << name << " : " << arg1 << endl;}template <typename Arg1, typename... Args>void __f (const char* names, Arg1&& arg1, Args&&... args){const char* comma = strchr (names + 1, ',');cout.write (names, comma - names) << " : " << arg1 << " | "; __f (comma + 1, args...);}
void solve(ll cs) {
ll n, k;
cin >> n >> k;
string s;
cin >> s;
vector<ll> v;
ll cnt=0;
for(ll i=0; i<n; i++){
if(s[i]=='1') cnt++;
else{
if(cnt) v.push_back(cnt);
cnt = 0;
}
}
if(cnt) v.push_back(cnt);
sort(v.rbegin(), v.rend());
//for(auto u:v) cout << u << " ";
//bug(v.size(), k)
ll sz = v.size();
ll ans = 0;
if(k<sz) for(int i=0; i<=k; i++) ans += v[i];
else for(int i=0; i<sz; i++) ans += v[i];
cout << ans << endl;
}
int main() {
ios_base::sync_with_stdio(false);
cin.tie(0), cout.tie(0);
ll t=1, cs=1;
cin>>t;
while(t--) {
solve(cs++);
}
return 0;
}