A - Potion-making
题意:加精华和加水配置成 k k k%的魔法水最少加几步
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int n, m, t;
int main() {
cin>>t;
while(t--) {
cin>>n;
cout<<100/__gcd(n, 100)<<endl;
}
return 0;
}
B - Permutation Sort
题意:给你一个序列,你可以选择小于 n n n长度的连续区间进行任意排序,最少要几次才能排好
#include<bits/stdc++.h>
using namespace std;
const int N = 1e4 + 86;
typedef long long ll;
int n, m, t, a[N], b[N], flag, q;
int main() {
cin>>t;
while(t--) {
cin>>n;
q=0;
for(int i=1; i<=n; i++) {
cin>>a[i];
if(a[i]!=i) q=1;
}
if(q==0) cout<<0<<endl;
else if(a[1]==n&&a[n]==1) cout<<3<<endl;//这里要注意
else if(a[1]==1||a[n]==n) cout<<1<<endl;
else cout<<2<<endl;
}
return 0;
}
C - Armchairs
D - Armchairs
题意:给你个01序列,问把1移到0上最少走路步数
佬的题解
类似题目链接
贪心wa8 样例 00110011
总结
A B