Submission #28761328
Source Code Expand
#include<bits/stdc++.h>
using namespace std;
template <class T>
inline T read(){
T r=0,f=0;char c=getchar();
while(!isdigit(c)) f|=c=='-',c=getchar();
while(isdigit(c)) r=(r<<3)+(r<<1)+(c^48),c=getchar();
return f?-r:r;
}
const int N=1e5+5,INF=1e9;
int n,a[N];
const double eps=1e-5;
bool check(double mid){
double f[N];
f[1]=a[1]-mid;
for(int i=2;i<=n;++i) f[i]=-INF;
for(int i=2;i<=n;++i) f[i]=max(f[i-1]+a[i]-mid,f[i-2]+a[i]-mid);
return f[n]>0||f[n-1]>0;
}
bool check(int mid){
int del=0,cntmax=0,cntmin=0;
for(int i=1;i<=n;++i){
if(a[i]<mid){
if(del+1==i) continue;
del=i,++cntmin;
}
else del=i,++cntmax;
}
return cntmin<cntmax;
}
int main(){
n=read<int>();
for(int i=1;i<=n;++i) a[i]=read<int>();
double l1=0,r1=1e9,ans1;
while(r1-l1>eps){
double mid=(l1+r1)/2;
if(check(mid)) ans1=mid,l1=mid;
else r1=mid;
}
int l=0,r=1e9,ans2;
while(l<=r){
int mid=l+r>>1;
if(check(mid)) ans2=mid,l=mid+1;
else r=mid-1;
}
printf("%lf\n%d",ans1,ans2);
return 0;
}
Submission Info
| Submission Time | |
|---|---|
| Task | E - Average and Median |
| User | Quick_Kk |
| Language | C++ (GCC 9.2.1) |
| Score | 500 |
| Code Size | 1190 Byte |
| Status | AC |
| Exec Time | 42 ms |
| Memory | 4880 KiB |
Compile Error
./Main.cpp: In function ‘int main()’:
./Main.cpp:42:18: warning: suggest parentheses around ‘+’ inside ‘>>’ [-Wparentheses]
42 | int mid=l+r>>1;
| ~^~
Judge Result
| Set Name | Sample | All | ||||
|---|---|---|---|---|---|---|
| Score / Max Score | 0 / 0 | 500 / 500 | ||||
| Status |
|
|
| Set Name | Test Cases |
|---|---|
| Sample | example_00.txt, example_01.txt |
| All | example_00.txt, example_01.txt, test_00.txt, test_01.txt, test_02.txt, test_03.txt, test_04.txt, test_05.txt, test_06.txt, test_07.txt, test_08.txt, test_09.txt, test_10.txt, test_11.txt, test_12.txt, test_13.txt, test_14.txt, test_15.txt, test_16.txt, test_17.txt, test_18.txt, test_19.txt, test_20.txt, test_21.txt, test_22.txt, test_23.txt, test_24.txt, test_25.txt, test_26.txt, test_27.txt, test_28.txt, test_29.txt, test_30.txt |
| Case Name | Status | Exec Time | Memory |
|---|---|---|---|
| example_00.txt | AC | 1 ms | 3676 KiB |
| example_01.txt | AC | 2 ms | 3652 KiB |
| test_00.txt | AC | 41 ms | 4664 KiB |
| test_01.txt | AC | 42 ms | 4720 KiB |
| test_02.txt | AC | 32 ms | 4424 KiB |
| test_03.txt | AC | 38 ms | 4372 KiB |
| test_04.txt | AC | 38 ms | 4612 KiB |
| test_05.txt | AC | 19 ms | 4028 KiB |
| test_06.txt | AC | 17 ms | 4036 KiB |
| test_07.txt | AC | 23 ms | 4248 KiB |
| test_08.txt | AC | 37 ms | 4772 KiB |
| test_09.txt | AC | 30 ms | 4404 KiB |
| test_10.txt | AC | 33 ms | 4820 KiB |
| test_11.txt | AC | 32 ms | 4876 KiB |
| test_12.txt | AC | 29 ms | 4660 KiB |
| test_13.txt | AC | 27 ms | 4632 KiB |
| test_14.txt | AC | 31 ms | 4668 KiB |
| test_15.txt | AC | 39 ms | 4880 KiB |
| test_16.txt | AC | 38 ms | 4756 KiB |
| test_17.txt | AC | 29 ms | 4252 KiB |
| test_18.txt | AC | 25 ms | 4248 KiB |
| test_19.txt | AC | 32 ms | 4812 KiB |
| test_20.txt | AC | 33 ms | 4804 KiB |
| test_21.txt | AC | 33 ms | 4808 KiB |
| test_22.txt | AC | 17 ms | 4192 KiB |
| test_23.txt | AC | 6 ms | 3704 KiB |
| test_24.txt | AC | 8 ms | 3836 KiB |
| test_25.txt | AC | 28 ms | 4836 KiB |
| test_26.txt | AC | 31 ms | 4832 KiB |
| test_27.txt | AC | 3 ms | 3696 KiB |
| test_28.txt | AC | 32 ms | 4636 KiB |
| test_29.txt | AC | 35 ms | 4776 KiB |
| test_30.txt | AC | 27 ms | 4844 KiB |