首页 > 其他分享 >AT_abc352_d

AT_abc352_d

时间:2024-05-18 17:43:22浏览次数:22  
标签:题目 int 1000001 abc352 下标 include

看到题目后,第一反应便是暴力枚举确定 \(i\)。但是看到了 \(N \le 2 \times 10^5\),这种想法便不合适了。观察题目第二个条件,不难发现其实真正合法的方案很少。于是可以转变方向,枚举题目要求的排列集合

想到这步,接下来就不难了。确定好原排列中被选的数后,需要求出它们的下标的最小值和最大值。又由于这些数本身是连续的,因此可以用这些数作为下标,存储它们原先的下标。这样做就把这些下标集中在一起了,转换为区间最值查询问题,用各种数据结构维护即可。

以下采用 ST 表实现,时间复杂度 \(O( n \log n )\)。

#include <iostream>
#include <cstdio>
#include <cmath>
#define int long long

using namespace std;

int n,k,p,ans,a[1000001],st1[1000001][20],st2[1000001][20],lg[1000001];

void rd( void )
{
	for( int j = 1 ; j <= 19 ; j ++ )
		for( int i = 1 ; i + ( 1 << ( j - 1 ) ) <= n ; i ++ )
		{
			st1[i][j] = max( st1[i][j - 1] , st1[i + ( 1 << ( j - 1 ) )][j - 1] );
			st2[i][j] = min( st2[i][j - 1] , st2[i + ( 1 << ( j - 1 ) )][j - 1] );
		}
}

int query( int l , int r )
{
	int d = lg[r - l + 1];
	int ans1 = max( st1[l][d] , st1[r - ( 1 << d ) + 1][d] );
	int ans2 = min( st2[l][d] , st2[r - ( 1 << d ) + 1][d] );
	return abs( ans1 - ans2 );
}

signed main()
{
	cin >> n >> k;
	for( int i = 2 ; i <= n ; i ++ )
		lg[i] = lg[i >> 1] + 1;
	for( int i = 1 ; i <= n ; i ++ )
	{
		cin >> p;
		a[p] = i;
		st1[p][0] = st2[p][0] = i;
	}
	rd();
	ans = n;
	for( int i = 1 ; i + k - 1 <= n ; i ++ )
		ans = min( ans , query( i , i + k - 1 ) );
	cout << ans;
	return 0;
}

标签:题目,int,1000001,abc352,下标,include
From: https://www.cnblogs.com/-lilong-/p/18199552

相关文章

  • 题解:AT_abc352_C [ABC352C] Standing On The Shoulders
    考场憋了很久,最后代码贼短……理想状态下,直接全排列解决问题。但是,\(1\len\le2\times10^5\),明显TLE,试都不用试的。咋优化呢?其实,前面的巨人只负责“打地基”,作为“塔尖儿”的巨人有且仅有1个。而前面地基随便排列,地基高度(他们的和)都不会变。所以,我们只需要枚举塔尖即......
  • ABC352
    Alink\(x\)停不到,\(y\)能停到。要先判断是从前往后还是从后往前。点击查看代码#include<bits/stdc++.h>usingnamespacestd;signedmain(){ intn,x,y,z; cin>>n>>x>>y>>z; if(x<=y){ if(z>x&&z<=y)cout<<......
  • ABC352
    A.AtCoderLine判断\(z\)是否出现在\(x\)和\(y\)之间即可代码实现n,x,y,z=map(int,input().split())ifx>y:x,y=y,xifx<z<y:print('Yes')else:print('No')B.Typing模拟代码实现#include<bits/stdc++.h......
  • AtCoder abc352
    EProblemStatementYouaregivenaweightedundirectedgraph$G$with$N$vertices,numbered$1$to$N$.Initially,$G$hasnoedges.Youwillperform$M$operationstoaddedgesto$G$.The$i$-thoperation$$(1\leqi\leqM)$$isasfollows:Youar......