제출 #361250

#제출 시각아이디문제언어결과실행 시간메모리
361250MilosMilutinovicMoney (IZhO17_money)C++14
100 / 100
199 ms15152 KiB
#include <bits/stdc++.h>
using namespace std;
const int N=1000050;
int n,a[N],bit[N];
int Get(int x){int res=0;for(;x>0;x-=x&(-x))res+=bit[x];return res;}
void Add(int x){for(;x<N;x+=x&(-x))bit[x]++;}
int main(){
    scanf("%i",&n);
    for(int i=1;i<=n;i++)scanf("%i",&a[i]);
    int j=1,ans=1;
    for(int i=2;i<=n;i++){
        if(a[i]<a[i-1]||Get(a[i]-1)>Get(a[j])){
            ans++;
            while(j<i)Add(a[j]),j++;
        }
    }
    printf("%i",ans);
    return 0;
}

컴파일 시 표준 에러 (stderr) 메시지

money.cpp: In function 'int main()':
money.cpp:8:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
    8 |     scanf("%i",&n);
      |     ~~~~~^~~~~~~~~
money.cpp:9:31: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
    9 |     for(int i=1;i<=n;i++)scanf("%i",&a[i]);
      |                          ~~~~~^~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...