题意
题解
代码
#include
#include
using namespace std;
const int N=110;
char a[N],b[N];
void solve() {
int n; cin>>n;
int a0=0,b0=0,diff=0;
for(int i=0;i<n;i++) {
cin>>a[i];
if(a[i]=='0') a0++;
}
for(int i=0;i<n;i++) {
cin>>b[i];
if(b[i]=='0') b0++;
if(a[i]!=b[i]) diff++;
}
if(diff==0) {cout<<0<<'\n'; return;}//本身有序,无需操作
if(a0==b0) {cout<<1<<'\n'; return ;}//无序但是数量差为0,所以只需排序
int x=abs(a0-b0);
if(x==diff) cout<<x<<'\n';//补齐x的数量差后,发现是有序的
else cout<<x+1<<'\n';//补齐后无序,需要额外一次排序
}
int main() {
int t; cin>>t;
while(t--) solve();
return 0;
}
题意
题解
代码
#include
#include
using namespace std;
const int N=1e5+10;
int a[N],b[N];
int lcm(int a,int b) {
return a*b/__gcd(a,b);
}
bool solve() {
int n; cin>>n;
for(int i=1;i<=n;i++) cin>>a[i];
b[1]=a[1];
for(int i=2;i<=n;i++) b[i]=lcm(a[i-1],a[i]);
b[n+1]=a[n];
for(int i=1;i<=n;i++)
if(__gcd(b[i],b[i+1])!=a[i]) return 0;
return 1;
}
int main() {
int t; cin>>t;
while(t--) cout<<(solve() ? "YES":"NO")<<'\n';
return 0;
}
题意
题解
代码
#include
#include
using namespace std;
const int N=2e5+10;
int a[N];
long long solve() {
int n; cin>>n;
for(int i=1;i<=n;i++) cin>>a[i];
long long ans=0;
for(int i=1,j=1;i<=n;i++) {
while(j<=n && a[j]>=j-i+1) j++;
ans+=(j-i);
}
return ans;
}
int main() {
int t; cin>>t;
while(t--) cout<<solve()<<'\n';
return 0;
}
dp
#include
usiung namespace std;
const int N=2e5+10;
int n,a[N],f[N];
long long solve() {
cin>>n;
for(int i=1;i<=n;i++) cin>>a[i],f[i]=0;
f[1]=1;
long long ans=0;
for(int i=1;i<=n;i++) {
f[i]=min(f[i-1],a[i]);
ans+=f[i];
}
return ans;
}
int main() {
int t; cin>>t;
while(t--) cout<<solve()<<'\n';
return 0;
}