20181031noip模拟赛T1
思路:
我们会发现不合法的位置只有两种情况
要么在前半边,要么在后半边
那么,我们将序列劈两次
使两次的长度分别为:
(n为偶数时要特判一下,因为根本不可能)
(n/2),(n/2+1)
(n/2+1),(n/2)
分别暴力贪心的匹配就好
但是,想ACACACACA这种,就会出锅
特判一下就好
代码:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define rii register int i
#define rij register int j
#define p1 19260817
#define p2 998244353
using namespace std;
int n,t;
char ls[];
int hash1()
{
long long ans=;
for(rii=;i<=n/;i++)
{
ans*=ls[i];
ans%=p1;
}
return ans;
}
int hash2()
{
long long ans=;
for(rii=;i<=n/;i++)
{
ans*=ls[i];
ans%=p2;
}
return ans;
}
int pash1()
{
long long ans=;
for(rii=(n+)/+;i<=n;i++)
{
ans*=ls[i];
ans%=p1;
}
return ans;
}
int pash2()
{
long long ans=;
for(rii=(n+)/+;i<=n;i++)
{
ans*=ls[i];
ans%=p2;
}
return ans;
}
void solve()
{
scanf("%d\n",&n);
int cnt=,wz=;
for(rii=;i<=n;i++)
{
cnt++;
ls[i]=getchar();
}
scanf("\n");
if(n%==)
{
puts("NOT POSSIBLE");
return;
}
int dp=;
for(rii=;i<=n-;i++)
{
if(ls[i]!=ls[i+])
{
dp=;
break;
}
}
if(dp==)
{
puts("NOT UNIQUE");
return;
}
int bnt=n/;
int sl=,pd=;
for(int i=;i<=n/;i++)
{
bnt++;
if(ls[i]!=ls[bnt])
{
bnt++;
pd++;
if(ls[bnt]!=ls[i])
{
pd++;
}
}
if(pd>=)
{
break;
}
}
int cs1=,cs2=;
if(pd<=)
{
sl++;
cs1=hash1();
cs2=hash2();
wz=;
}
pd=,bnt=;
int kkk=(n+)/;
for(int i=kkk+;i<=n;i++)
{
bnt++;
if(ls[bnt]!=ls[i])
{
bnt++;
pd++;
if(ls[bnt]!=ls[i])
{
pd++;
}
}
if(pd>=)
{
break;
}
}
if(pd<=)
{
sl++;
wz=;
}
if(sl==)
{
if(cs1==pash1()&&cs2==pash2())
{
sl--;
}
}
if(sl==)
{
puts("NOT UNIQUE");
}
if(sl==)
{
puts("NOT POSSIBLE");
}
if(sl==)
{
if(wz==)
{
int ltt=n/;
for(rii=;i<=ltt;i++)
{
putchar(ls[i]);
}
putchar();
}
else
{
int ltt=(n+)/;
for(rii=ltt+;i<=n;i++)
{
putchar(ls[i]);
}
putchar();
}
}
}
int main()
{
freopen("lgg.in","r",stdin);
freopen("lgg.out","w",stdout);
scanf("%d\n",&t);
for(rii=;i<=t;i++)
{
solve();
}
return ;
}
20181031noip模拟赛T1的更多相关文章
- 【洛谷比赛】[LnOI2019]长脖子鹿省选模拟赛 T1 题解
今天是[LnOI2019]长脖子鹿省选模拟赛的时间,小编表示考的不怎么样,改了半天也只会改第一题,那也先呈上题解吧. T1:P5248 [LnOI2019SP]快速多项式变换(FPT) 一看这题就很手 ...
- 20180610模拟赛T1——脱离地牢
Description 在一个神秘的国度里,年轻的王子Paris与美丽的公主Helen在一起过着幸福的生活.他们都随身带有一块带磁性的阴阳魔法石,身居地狱的魔王Satan早就想着得到这两块石头了,只要 ...
- NOIP欢乐模拟赛 T1 解题报告
小澳的方阵 (matrix.cpp/c/pas) [题目描述] 小澳最近迷上了考古,他发现秦始皇的兵马俑布局十分有特点,热爱钻研的小澳打算在电脑上还原这个伟大的布局. 他努力钻研,发现秦始皇布置兵马俑 ...
- [模拟赛] T1 高级打字机
Description 早苗入手了最新的高级打字机.最新款自然有着与以往不同的功能,那就是它具备撤销功能,厉害吧. 请为这种高级打字机设计一个程序,支持如下3种操作: 1.T x:在文章末尾打下一个小 ...
- 2019.2.25 模拟赛T1【集训队作业2018】小Z的礼物
T1: [集训队作业2018]小Z的礼物 我们发现我们要求的是覆盖所有集合里的元素的期望时间. 设\(t_{i,j}\)表示第一次覆盖第i行第j列的格子的时间,我们要求的是\(max\{ALL\}\) ...
- [NOIP2018校模拟赛]T1 阶乘
题目: 描述 有n个正整数a[i],设它们乘积为p,你可以给p乘上一个正整数q,使p*q刚好为正整数m的阶乘,求m的最小值. 输入 共两行. 第一行一个正整数n. 第二行n个正整数a[i]. 输出 共 ...
- [NOIP2018校模拟赛]T1聚会 party
题目链接: 聚会 分析: 设每个点到1号点的距离为dist_{i},每个点的权值为x_{i},目标点到1号点的距离为dist,权值为x,那么对于每一次查询,我们讨论三种情况: ① 目标家庭在区间左边( ...
- 【2019.8.15 慈溪模拟赛 T1】插头(plugin)(二分+贪心)
二分 首先,可以发现,最后的答案显然满足可二分性,因此我们可以二分答案. 然后,我们只要贪心,就可以验证了. 贪心 不难发现,肯定会优先选择能提供更多插座的排插,且在确定充电器个数的情况下,肯定选择能 ...
- 【2019.7.20 NOIP模拟赛 T1】A(A)(暴搜)
打表+暴搜 这道题目,显然是需要打表的,不过打表的方式可以有很多. 我是打了两个表,分别表示每个数字所需的火柴棒根数以及从一个数字到另一个数字,除了需要去除或加入的火柴棒外,至少需要几根火柴棒. 然后 ...
随机推荐
- .NET开源工作流RoadFlow-流程设计-流程步骤设置-事件设置
事件设置是设置当前步骤在提交前后或退回前后要执行的一些操作(该事件为服务器事件). 事件格式为:dll名称.命名空间名称.类名.方法名,这里不需要写括号和参数,处理时会自动带上当前流程实例的相关参数. ...
- VC学习笔记---ATL MFC CLR三个库的区别
MFC.ATL和CLR是VC2005内置的三大库,涵盖了Windows的各种开发方法和开发应用.当然关于C++开发的库不止这三个,不过这三个是微软推荐. 从编程所处层次而言,WIN32为最底层,其次是 ...
- python学习笔记之——正则表达式
1.re模块 Python通过re模块提供对正则表达式的支持,re 模块使 Python 语言拥有全部的正则表达式功能.使用re的一般步骤是先将正则表达式的字符串形式编译为Pattern实例,然后使用 ...
- 实用爬虫-01-检测爬虫的 IP
实用爬虫-01-检测爬虫的 IP 本篇介绍一个识别爬虫 ip 的小实例(教你一招识破无效的 ip 代理) [注意事项]: 1.url 可能会失效(个人感觉,因为它带了一个2018,下面附上链接获取方法 ...
- 使用ZXing实现扫描多个条形码页面
1.前言 ZXing是google官方推出的跨平台的基于Java实现处理扫面二维码或者条形码的库.支持很多格式,一维条码支持UPC-A,UPC-E,EAN-8,Code 39,Code 93等格式,二 ...
- 规划将 IaaS 资源从经典部署模型迁移到 Azure Resource Manager
尽管 Azure 资源管理器提供了许多精彩功能,但请务必计划迁移,以确保一切顺利进行. 花时间进行规划可确保执行迁移活动时不会遇到问题. Note 以下指导的主要参与者为 Azure 客户顾问团队,以 ...
- Kendo 计算字段
var Product = kendo.data.Model.define({ fields: { "quantity": { type: "number" } ...
- Linux基础入门 - 3
第四节 Linux 目录结构及文件基本操作 4-1.Linux目录结构 Linux 的目录与 Windows 的目录的实现机制是完全不同的.一种不同是体现在目录与存储介质(磁盘,内存,DVD 等)的关 ...
- post注入及提权思路
我们这次的目标有点敏感 性感的马赛克是必须有的 登陆表单 那么我们来看看是不是存在post注入 Setp1:设置代理 Step2:账户admin密码随意 提交上去 抓个包 把抓到的包复制到本地的一 ...
- 由JDK源码学习ArrayList
ArrayList是实现了List接口的动态数组.与java中的数组相比,它的容量能动态增长.ArrayList的三大特点: ① 底层采用数组结构 ② 有序 ③ 非同步 下面我们从ArrayList的 ...