Submission #2517519
Source Code Expand
// g++ -std=c++11 a.cpp
#include<iostream>
#include<vector>
#include<string>
#include<algorithm>
#include<map>
#include<set>
#include<unordered_map>
#include<utility>
#include<cmath>
#include<random>
#include<cstring>
#include<queue>
#include<stack>
#include<bitset>
#include<cstdio>
#include<sstream>
#include<iomanip>
#include<assert.h>
#include<typeinfo>
#define loop(i,a,b) for(int i=a;i<b;i++)
#define rep(i,a) loop(i,0,a)
#define FOR(i,a) for(auto i:a)
#define pb push_back
#define all(in) in.begin(),in.end()
#define shosu(x) fixed<<setprecision(x)
using namespace std;
//kaewasuretyuui
typedef long long ll;
//#define int ll
typedef int Def;
typedef pair<Def,Def> pii;
typedef vector<Def> vi;
typedef vector<vi> vvi;
typedef vector<pii> vp;
typedef vector<vp> vvp;
typedef vector<string> vs;
typedef vector<double> vd;
typedef vector<vd> vvd;
typedef pair<Def,pii> pip;
typedef vector<pip>vip;
#define mt make_tuple
typedef tuple<int,int,int> tp;
typedef vector<tp> vt;
template<typename A,typename B>bool cmin(A &a,const B &b){return a>b?(a=b,true):false;}
template<typename A,typename B>bool cmax(A &a,const B &b){return a<b?(a=b,true):false;}
//template<class C>constexpr int size(const C &c){return (int)c.size();}
//template<class T,size_t N> constexpr int size(const T (&xs)[N])noexcept{return (int)N;}
const double PI=acos(-1);
const double EPS=1e-9;
Def inf = sizeof(Def) == sizeof(long long) ? 2e18 : 1e9+10;
int dx[]={0,1,0,-1};
int dy[]={1,0,-1,0};
class SST{
public:
int n;
vi a,b;
SST(int size){
n=pow(2,ceil(log2(size)));
a=b=vi(2*n-1);
}
void range_add(int l,int r,int z){//[l,r)+=z
range_add(0,0,n,l,r,z);
}
void range_add(int i,int il,int ir,int l,int r,int z){//[l,r)
if(l<=il&&ir<=r){
a[i]+=z;
b[i]+=z;
}else if(ir<=l||r<=il){
}else{
range_add(2*i+1,il,(il+ir)/2,l,r,z);
range_add(2*i+2,(il+ir)/2,ir,l,r,z);
b[i]=a[i]+max(b[2*i+1],b[2*i+2]);//max
}
}
int range_max(int l,int r){
return range_max(0,0,n,l,r);
}
int range_max(int i,int il,int ir,int l,int r){
if(l<=il&&ir<=r){
return b[i];
}else if(ir<=l||r<=il){
return 0;
}else{
return a[i]+max(
range_max(2*i+1,il,(il+ir)/2,l,r),
range_max(2*i+2,(il+ir)/2,ir,l,r));
}
}
void open(){
rep(i,a.size())cout<<" "<<a[i];cout<<endl;
rep(i,b.size())cout<<" "<<b[i];cout<<endl;
}
};
int main(){
int n,m;
cin>>n>>m;
vvp in(m);
rep(i,n){
int a,b;cin>>a>>b;
in[b-a].pb({a,b});
}
int s=n;
SST sst(m);
rep(i,m){
int co=s;
for(int j=i+1;j<=m;j+=i+1){
co+=sst.range_max(j-1,j);
}
cout<<co<<endl;
s-=in[i].size();
rep(j,in[i].size())
sst.range_add(in[i][j].first-1,in[i][j].second,1);
}
}
Submission Info
Submission Time |
|
Task |
E - Snuke Line |
User |
ixmel_rd |
Language |
C++14 (GCC 5.4.1) |
Score |
700 |
Code Size |
2789 Byte |
Status |
AC |
Exec Time |
603 ms |
Memory |
9728 KB |
Judge Result
Set Name |
Sample |
All |
Score / Max Score |
0 / 0 |
700 / 700 |
Status |
|
|
Set Name |
Test Cases |
Sample |
00_example_01.txt, 00_example_02.txt |
All |
00_example_01.txt, 00_example_02.txt, 01.txt, 02.txt, 03.txt, 04.txt, 05.txt, 06.txt, 07.txt, 08.txt, 09.txt, 10.txt, 11.txt, 12.txt, 13.txt, 14.txt, 15.txt, 16.txt, 17.txt, 18.txt, 19.txt, 20.txt, 21.txt, 22.txt, 23.txt, 24.txt, 25.txt, 26.txt, 27.txt, 28.txt, 29.txt, 30.txt, 31.txt, 32.txt, 33.txt, 34.txt, 35.txt, 36.txt, 37.txt |
Case Name |
Status |
Exec Time |
Memory |
00_example_01.txt |
AC |
1 ms |
256 KB |
00_example_02.txt |
AC |
1 ms |
256 KB |
01.txt |
AC |
1 ms |
256 KB |
02.txt |
AC |
2 ms |
256 KB |
03.txt |
AC |
2 ms |
256 KB |
04.txt |
AC |
1 ms |
256 KB |
05.txt |
AC |
3 ms |
256 KB |
06.txt |
AC |
3 ms |
256 KB |
07.txt |
AC |
1 ms |
256 KB |
08.txt |
AC |
2 ms |
256 KB |
09.txt |
AC |
2 ms |
256 KB |
10.txt |
AC |
1 ms |
256 KB |
11.txt |
AC |
348 ms |
6272 KB |
12.txt |
AC |
587 ms |
9600 KB |
13.txt |
AC |
206 ms |
4096 KB |
14.txt |
AC |
179 ms |
3712 KB |
15.txt |
AC |
177 ms |
3840 KB |
16.txt |
AC |
306 ms |
5376 KB |
17.txt |
AC |
603 ms |
9600 KB |
18.txt |
AC |
172 ms |
3836 KB |
19.txt |
AC |
589 ms |
9600 KB |
20.txt |
AC |
586 ms |
9600 KB |
21.txt |
AC |
589 ms |
9600 KB |
22.txt |
AC |
583 ms |
9600 KB |
23.txt |
AC |
596 ms |
9600 KB |
24.txt |
AC |
522 ms |
7804 KB |
25.txt |
AC |
211 ms |
3832 KB |
26.txt |
AC |
172 ms |
3452 KB |
27.txt |
AC |
544 ms |
8576 KB |
28.txt |
AC |
224 ms |
4344 KB |
29.txt |
AC |
562 ms |
8704 KB |
30.txt |
AC |
242 ms |
4212 KB |
31.txt |
AC |
537 ms |
8576 KB |
32.txt |
AC |
226 ms |
4096 KB |
33.txt |
AC |
182 ms |
3712 KB |
34.txt |
AC |
532 ms |
9728 KB |
35.txt |
AC |
532 ms |
8448 KB |
36.txt |
AC |
1 ms |
256 KB |
37.txt |
AC |
328 ms |
4864 KB |