社区讨论
谁来救救我!时间复杂度!!!
P9485「LAOI-1」积水参与者 1已保存回复 0
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 0 条
- 当前快照
- 1 份
- 快照标识符
- @m0rjzr3q
- 此快照首次捕获于
- 2024/09/07 10:56 去年
- 此快照最后确认于
- 2024/09/07 13:57 去年
不想说什么,时间复杂度是一座高山啊!
测试数据
CPP#include <bits/stdc++.h>
using namespace std;
typedef long long shuju;
const shuju NUM=1000030;
shuju shuikeng(shuju a[],shuju n)
{
shuju l[NUM]={0};
shuju r[NUM]={0};
shuju ans=0;
for(int i=0;i<n;i++)
{
int j=n-1-i;
l[i]=max(l[i-1],a[i]);
r[j]=max(r[j+1],a[j]);
}
for(int i=1;i<=n;i++)
{
if(min(l[i],r[i])-a[i]>=0)
{
ans+=min(l[i],r[i])-a[i];
}
}
return ans;
}
int main()
{
shuju t=0;
cin>>t;
for(shuju i=0;i<t;i++)
{
shuju n=0;
shuju ans=100000000;
shuju tsk[NUM]={0};
cin>>n;
for(shuju j=0;j<n;j++)
{
cin>>tsk[j];
}
for(shuju j=0;j<n;j++)
{
/*for(shuju k=1;k<tsk[j];k++)
{
shuju temp=tsk[j];
tsk[j]-=k;
ans=min(ans,shuikeng(tsk,n));
tsk[j]=temp;
}*/
shuju temp=tsk[j];
tsk[j]=1;
ans=min(ans,shuikeng(tsk,n));
tsk[j]=temp;
}
cout<<ans<<endl;
}
return 0;
}
回复
共 0 条回复,欢迎继续交流。
正在加载回复...