제출 #70760

#제출 시각아이디문제언어결과실행 시간메모리
70760KLPPBubble Sort 2 (JOI18_bubblesort2)C++14
38 / 100
7223 ms5024 KiB
#include "bubblesort2.h" #include<vector> #include<iostream> #include<algorithm> #include<set> using namespace std; typedef long long int lld; #define INF 1000000000 class FT{ int arr[100000]; int n; public: void init(int N){ n=N; for(int i=0;i<=n;i++){ arr[i]=0; } } int query(int prefix){ prefix++; int ans=0; for(;prefix>0;prefix-=(prefix&(-prefix))){ ans+=arr[prefix]; }return ans; } void update(int pos){ pos++; for(;pos<=n;pos+=(pos&(-pos))){ arr[pos]++; } } void print(){ for(int i=0;i<=n;i++){ cout<<arr[i]<<" "; }cout<<endl; } }; FT *F; int compute(vector<int> v){ int n=v.size(); F->init(n); pair<int,int> arr[n]; for(int i=0;i<n;i++){ arr[i]=pair<int,int>(v[i],i); }sort(arr,arr+n); int prev=n-1; int ans=0; for(int i=n-1;i>-1;i--){ if(i==0 || arr[i-1]!=arr[i]){ for(int j=prev;j>=i;j--){ ans=max(ans,F->query(arr[j].second)); } for(int j=prev;j>=i;j--){ F->update(arr[j].second); } prev=i-1; } } return ans; } struct node{ int l,r; int val; node *left,*right; }; void build(node *n,int l, int r){ } std::vector<int> countScans(std::vector<int> A,std::vector<int> X,std::vector<int> V){F=new FT(); if(A.size()<=8000){ vector<int> ans; for(int i=0;i<X.size();i++){ A[X[i]]=V[i]; ans.push_back(compute(A)); } return ans; } set<int> arr[100]; for(int i=0;i<A.size();i++){ arr[A[i]-1].insert(i); //cout<<A[i]-1<<" "<<i<<endl; } vector<int> a; for(int i=0;i<X.size();i++){ arr[A[X[i]]-1].erase(X[i]); arr[V[i]-1].insert(X[i]); A[X[i]]=V[i]; //cout<<X[i]<<" "<<V[i]<<endl; vector<int>H; for(int j=0;j<100;j++){ if(arr[j].size()>0){ std::set<int>::iterator it2=arr[j].begin(); H.push_back(*it2); } } //for(int j=0;j<H.size();j++)cout<<H[j]<<endl; //cout<<compute(H)<<endl; a.push_back(compute(H)); }//cout<<ans.size()<<endl; //for(int i=0;i<a.size();i++)cout<<a[i]<<endl; return a; }

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

bubblesort2.cpp: In function 'std::vector<int> countScans(std::vector<int>, std::vector<int>, std::vector<int>)':
bubblesort2.cpp:72:15: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for(int i=0;i<X.size();i++){
              ~^~~~~~~~~
bubblesort2.cpp:80:15: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for(int i=0;i<A.size();i++){
              ~^~~~~~~~~
bubblesort2.cpp:85:15: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for(int i=0;i<X.size();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...