https://code.google.com/codejam/contest/6224486/dashboard#s=p2

题目中的新运算满足传递性不满足自反性,满足传递性则可以先计算后面的部分再计算前面的,明显设每节的计算结果为val,则要成功必然需要val*val^(x-1)(也就是x个val相乘)恰为-1(i*j*k==-1),因为满足传递性,所以在此条件下,只需要取前面的一部分等于i,后面一部分等于k,中间一部分就会等于j了.

注意到无论每节的结果是什么,每四节的结果一定是1,所以左边的最小长度不会大于四节(否则会多一个1出来,没有用),同样,右边也不会大于四节,所以最小长度不会大于8节,直接把字符串缩小到8节以内展开即可也就是x%8

但是需要特殊注意的是,有两种情况

1. 原本大于8,x%8之后反而不满足题意了,这需要改成x%4+4

2. 在1的基础上,原本小于4,结果给改成大于4了,所以需要特判一下只有x>8的时候x=x%4+4

接下来直接展开计算即可

#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <iostream>
using namespace std;
typedef long long ll;
const int maxl=2.5e5+10;
int l;
ll x;
char str[maxl];
int val[maxl],rv[maxl]; int subcalc[255][255];
void initcalc(){
subcalc[1][1]=1;
subcalc[1][(int)'i']=(int)'i';
subcalc[1][(int)'j']=(int)'j';
subcalc[1][(int)'k']=(int)'k';
subcalc[(int)'i'][1]=(int)'i';
subcalc[(int)'j'][1]=(int)'j';
subcalc[(int)'k'][1]=(int)'k';
subcalc[(int)'i'][(int)'j']=(int)'k';
subcalc[(int)'j'][(int)'i']=-(int)'k';
subcalc[(int)'i'][(int)'k']=-(int)'j';
subcalc[(int)'k'][(int)'i']=(int)'j';
subcalc[(int)'j'][(int)'k']=(int)'i';
subcalc[(int)'k'][(int)'j']=-(int)'i';
subcalc[(int)'i'][(int)'i']=-1;
subcalc[(int)'j'][(int)'j']=-1;
subcalc[(int)'k'][(int)'k']=-1;
}
int calc(int a,int b){
int sign=a*b/abs(a)/abs(b);
a=abs(a);
b=abs(b);
return sign*(subcalc[a][b]);
}
int indi,indk;
void calvalue(){
val[0]=(int)str[0];
if(val[0]==(int)'i')indi=0;
else indi=0x7ffffff;
indk=-1;
for(int i=1;i<l;i++){
val[i]=calc(val[i-1],(int)str[i]);
if(val[i]==(int)'i'){
indi=min(indi,i);
}
}
rv[l]=1;
for(int i=l-1;i>=0;i--){
rv[i]=calc((int)str[i],rv[i+1]);
if(rv[i]==(int)'k'){
indk=max(indk,i);
}
}
} int main(){
freopen("data.in","r",stdin);
freopen("data.out","w",stdout);
initcalc();
int T;
cin>>T;
for(int ti=1;ti<=T;ti++){
cin>>l>>x>>str;
//printf("%d %I64d %s\n",l,x,str);
if(x>8){
x=x%4+4;
}
for(int i=1;i<x;i++){
for(int j=i*l;j<i*l+l;j++){
str[j]=str[j-i*l];
}
}
l*=x;
str[l]=0;
calvalue();
int fl=val[l-1];
if(fl!=-1||indi>=indk){
cout<<"Case #"<<ti<<": NO"<<endl;
}
else {
cout<<"Case #"<<ti<<": YES"<<endl;
}
}
return 0;
}

GCJ 2015-Qualification-C Dijkstra 特殊注意,展开 难度:2的更多相关文章

  1. [C++]Infinite House of Pancakes——Google Code Jam 2015 Qualification Round

    Problem It’s opening night at the opera, and your friend is the prima donna (the lead female singer) ...

  2. [C++]Standing Ovation——Google Code Jam 2015 Qualification Round

    Problem It’s opening night at the opera, and your friend is the prima donna (the lead female singer) ...

  3. VK Cup 2015 - Qualification Round 1 D. Closest Equals 离线+线段树

    题目链接: http://codeforces.com/problemset/problem/522/D D. Closest Equals time limit per test3 secondsm ...

  4. codeforces VK Cup 2015 - Qualification Round 1 B. Photo to Remember 水题

    B. Photo to Remember Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/522/ ...

  5. Codeforces VK Cup 2015 - Qualification Round 1 D. Closest Equals 离线线段树 求区间相同数的最小距离

    D. Closest Equals Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/prob ...

  6. VK Cup 2015 - Qualification Round 1 A. Reposts [ dp DAG上最长路 ]

    传送门 A. Reposts time limit per test 1 second memory limit per test 256 megabytes input standard input ...

  7. POJ3463Sightseeing[次短路计数]

    Sightseeing Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 8707   Accepted: 3056 Descr ...

  8. Windows开发环境搭建(安装 VS2010, VS2013, VS2015 Community, Windows Server 2008 R2)

    1. 安装VS2010 1.1 安装步骤 1. 注意安装的时候,选择自定义安装,将不需要的VB.net去掉. 2. 看一下C++下的x64选项是否选择了,如果没选,将其选上. 3. 一定要将 Micr ...

  9. Linux64位程序中的漏洞利用

    之前在栈溢出漏洞的利用和缓解中介绍了栈溢出漏洞和一些常见的漏洞缓解 技术的原理和绕过方法, 不过当时主要针对32位程序(ELF32). 秉承着能用就不改的态度, IPv4还依然是互联网的主导, 更何况 ...

随机推荐

  1. Jdbc入门

    JDBC入门 l  导jar包:驱动! l  加载驱动类:Class.forName(“类名”); l  给出url.username.password,其中url背下来! l  使用DriverMa ...

  2. goLang文件遍历

    package main import (  "fmt"  "io/ioutil"  "os"  "path/filepath&q ...

  3. centos7 php7 安装composer时Failed to decode zlib stream解决办法

    1 下载安装脚本 php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');" 2 运行安装脚 ...

  4. MyBatis——实现关联表查询

    原文:http://www.cnblogs.com/xdp-gacl/p/4264440.html 一.一对一关联 1.1.提出需求 根据班级id查询班级信息(带老师的信息) 1.2.创建表和数据 创 ...

  5. Java集合的Stack、Queue、Map的遍历

    Java集合的Stack.Queue.Map的遍历   在集合操作中,常常离不开对集合的遍历,对集合遍历一般来说一个foreach就搞定了,但是,对于Stack.Queue.Map类型的遍历,还是有一 ...

  6. hdu 5755(高斯消元——模线性方程组模板)

    PS. 看了大神的题解,发现确实可以用m个未知数的高斯消元做.因为确定了第一行的情况,之后所有行的情况都可以根据第一行推. 这样复杂度直接变成O(m*m*m) 知道了是高斯消元后,其实只要稍加处理,就 ...

  7. 一张图看懂360°全景和VR的区别

    2016年开始,Facebook.谷歌.腾讯.阿里等互联网巨头都已开始抢食VR(虚拟现实)这块的大蛋糕,虚拟现实发展速度惊人.在这样强势发展的背景下,一些产品也开始打着VR的幌子,挂着VR的噱头卖起来 ...

  8. 基于 php-redis 的redis操作

    基于 php-redis 的redis操作 林涛 发表于:2016-5-13 12:12 分类:PHP 标签:php,php-redis,redis 203次 redis的操作很多的,下面的例子都是基 ...

  9. KD-tree

    就是K维空间上的二叉查找树. 每个node对应k维空间的超矩形区域 在方差最大的维度上,比较数据与kd-tree的根节点.中间节点,在该维度上的中值处划分,得到新的子空间,直到不能再分. 用于最近邻查 ...

  10. 基于SpringBoot项目的https

    在spring中配置项目运行的端口很简单. 在application.properties中 server.port: 这样配置后,spring boot内嵌的tomcat服务器就是跑在8080端口启 ...