洛谷P3514 [POI 2011] LIZ-Lollipop(思维题)

题目

思路来源

乱搞ac

题解

注意到一个区间两个端点都是2的话,此时和是sum,并且只能删掉一个2,那么sum-1一定拼不出来

那么如果一个区间两个端点有一个端点是1的话,此时和是sum,那么[1,sum]都能拼出来

不妨左端点是1,右端点是2,首先sum可以拼出来,删左端点就能拼出sum-1,删右端点就能拼出sum-2,然后删掉右端点,递归的考虑[1,sum-2]

不妨左端点是1,右端点是1,首先sum可以拼出来,删右端点就能拼出sum-1,然后删掉右端点,递归的考虑[1,sum-1]

数学归纳可知,[1,sum]都能拼出来

代码

cpp 复制代码
#include<bits/stdc++.h>
#include<iostream>
#include<cstdio>
#include<vector>
#include<map>
#include<set>
using namespace std;
#define rep(i,a,b) for(int i=(a);i<=(b);++i)
#define per(i,a,b) for(int i=(a);i>=(b);--i)
typedef long long ll;
typedef double db;
typedef pair<ll,ll> P;
typedef array<ll,3> A;
#define fi first
#define se second
#define pb push_back
#define dbg(x) cerr<<(#x)<<":"<<x<<" ";
#define dbg2(x) cerr<<(#x)<<":"<<x<<endl;
#define SZ(a) (int)(a.size())
#define sci(a) scanf("%d",&(a))
#define pt(a) printf("%d",a);
#define pte(a) printf("%d\n",a)
#define ptlle(a) printf("%lld\n",a)
const int N=1e6+10,M=2e6+10;
int n,m,sum,v;
char s[N];
P ok[M];
int main(){
    sci(n),sci(m);
    scanf("%s",s+1);
    int l=1,r=n,fir=0,sec=0;
    rep(j,1,n){//TT
        if(s[j]=='T')sum+=2;
        else sum++;
        if(!fir && s[j]=='W')fir=j;
        if(s[j]=='W')sec=j;
    }
    ok[sum]=P(l,r);
    while(l<=r){
        if(s[l]==s[r]){
            if(s[l]=='T'){
                sum-=2;
                if(!sec)l++;
                else if(fir<n-sec+1)l++;
                else r--;
            }
            else{
                sum--,l++;
            }
        }
        else{
            if(s[l]=='T'){
                ok[sum-1]=P(l,r-1);
                sum-=2;
                l++;
            }
            else{
                ok[sum-1]=P(l+1,r);
                sum-=2;
                r--;
            }
        }
        ok[sum]=P(l,r);
    }
    while(m--){
        sci(v);
        if(ok[v]==P(0,0))puts("NIE");
        else printf("%d %d\n",ok[v].fi,ok[v].se);
    }
    return 0;
}
相关推荐
小O的算法实验室21 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
郭涤生1 天前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿1 天前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz1 天前
leetcode学python记录1
python·算法·leetcode·职场和发展
汀、人工智能1 天前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****1 天前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能1 天前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能1 天前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数
CoderCodingNo1 天前
【GESP】C++四、五级练习题 luogu-P1177 【模板】排序
数据结构·c++·算法
Proxy_ZZ01 天前
从零实现LDPC比特翻转译码器:C语言实战与底层逻辑解析
c语言·算法