ZOJ 3818 Pretty Poem 模拟题
这题在比赛的时候WA到写不出来,也有判断ABC子串不一样不过写的很差一直WA
在整理清思路后重写一遍3Y
解题思路如下:
第一种情况:ABABA。 先判断开头的A与结尾的A,得到A的长度,
接着判断ABAB 中的AB与AB是否相同(ABAB的长度一定为偶数)
已经知道了A长度,AB的长度 接着判断下A 与B是否相同
第二种情况:ABABCAB-可先讲AB看成整体即DDCD
若存在一个D满足条件 可得到C的长度和位置再判断A-B是否相同A-C是否相同 B-C是否相同(暴力取A的长度咯)
其中在重写的时候WA的一个原因是这样的:
暴力A子串的长度的时候
for(int lena = 1; lena <= len / 3; ++lena){
这么写会导致WA
如果控制到位,这么写:
for(int lena = 1; lena <= (len - 2) / 3; ++lena){
就不会出现错误。
取D子串的时候也是同理。
看了别人写的代码,漫天飞舞的flag_1,flag_2,flag_3
还不如自己写一遍舒服多了
#include <stdio.h>
#include <string.h> int main(){
int n, i, j, k, t, m;
char array[], a[];
int len;
bool flag_a, flag_b;
scanf("%d",&t);
while(t--){
scanf("%s",array);
len = ;
flag_a = flag_b = false;
for(i = ; i < strlen(array); ++i){
if(array[i] >= 'A' && array[i] <= 'Z' || array[i] >= 'a' && array[i] <= 'z'){
a[len++] = array[i];
}
}
a[len] = '\0';
for(int lena = ; lena <= (len - ) / ; ++lena){
bool flag_1 = false;
for(i = ; i < lena; ++i){
if(a[i] != a[len - lena + i])
flag_1 = true;
}
if(flag_1) continue;
int remain_num = len - lena;
if(remain_num % != ) continue;
remain_num /= ;
for(i = ; i < remain_num; ++i){
if(a[i] != a[i + remain_num])
flag_1 = true;
}
if(flag_1) continue;
int lenb = remain_num - lena;
if(lena == lenb){
for(i = ; i < lena; ++i){
if(a[i] != a[i + lena]){
flag_a = true;
break;
}
}
if(flag_a) break;
} else{
flag_a = true;
break;
}
}
for(int lend = ; lend <= (len - ) / ; ++lend){
bool flag_2 = false;
for(i = ; i < lend; ++i){
if(!(a[i] == a[i + lend] && a[i] == a[len - lend + i]))
flag_2 = true;
}
if(flag_2) continue;
int lenc = len - * lend;
bool a_b = false;
for(int lena = ; lena < lend; ++lena){
if(lena == lend - lena){
for(i = ; i < lena; ++i){
if(a[i] != a[lena + i])
a_b = true;
}
if(!a_b) continue;
}
bool a_c = false;
bool b_c = false;
if(lena != lenc) a_c = true;
else{
for(i = ; i < lena; ++i){
if(a[i] != a[ * lend + i]){
a_c = true;
break;
}
}
}
int lenb = lend - lena;
if(lenb != lenc) b_c = true;
else{
for(i = ; i < lenb; ++i){
if(a[lena + i] != a[ * lend + i]){
b_c = true;
break;
}
}
}
if(a_c && b_c){
flag_b = true;
break;
}
}
if(flag_b){
break;
} } if(flag_a || flag_b){
printf("Yes\n");
} else{
printf("No\n");
}
}
return ;
}
ZOJ 3818 Pretty Poem 模拟题的更多相关文章
- ZOJ 3818 Pretty Poem
暴力模拟 细节处理很重要... #include <iostream> #include <cstring> #include <cstdio> using nam ...
- ZOJ 3790 Consecutive Blocks 模拟题
problemCode=3790">Consecutive Blocks 先离散一下,然后模拟,把一种颜色i所在的位置都放入G[i]中.然后枚举一下终点位置,滑动窗体使得起点和终点间花 ...
- Capture the Flag ZOJ - 3879(模拟题)
In computer security, Capture the Flag (CTF) is a computer security competition. CTF contests are us ...
- poj 1008:Maya Calendar(模拟题,玛雅日历转换)
Maya Calendar Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 64795 Accepted: 19978 D ...
- poj 1888 Crossword Answers 模拟题
Crossword Answers Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 869 Accepted: 405 D ...
- CodeForces - 427B (模拟题)
Prison Transfer Time Limit: 1000MS Memory Limit: 262144KB 64bit IO Format: %I64d & %I64u Sub ...
- sdut 2162:The Android University ACM Team Selection Contest(第二届山东省省赛原题,模拟题)
The Android University ACM Team Selection Contest Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里 ...
- 全国信息学奥林匹克联赛 ( NOIP2014) 复赛 模拟题 Day1 长乐一中
题目名称 正确答案 序列问题 长途旅行 英文名称 answer sequence travel 输入文件名 answer.in sequence.in travel.in 输出文件名 answer. ...
- UVALive 4222 Dance 模拟题
Dance 题目连接: https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&pag ...
随机推荐
- Python生成随机数的方法
这篇文章主要介绍了Python生成随机数的方法,有需要的朋友可以参考一下 如果你对在Python生成随机数与random模块中最常用的几个函数的关系与不懂之处,下面的文章就是对Python生成随机数与 ...
- 人类科技的发展为什么会是加速度的(TRIZ方法再推荐)
从人类的历史发展来看,近200年来的科技发展的成果超过了过去几千年中科技发展的成果,并且从短时间来看.这样的加速趋势也是很明显的,想想十年前和如今的对照,科技的发展确实是日新月异. 科技的发展固然有偶 ...
- (Problem 22)Names scores
Using names.txt (right click and 'Save Link/Target As...'), a 46K text file containing over five-tho ...
- shell学习之用户管理和文件属性
1.组和用户的添加 添加组: groupadd [-g gid [-o]] [-r] [-f] group 示例: groupadd -g testgoup1 #添加组testgroup1,同时指定g ...
- Sqlite出现SQL error: database disk image is malformed的处理
SQLite有一个很严重的缺点就是不提供Repair命令.导致死亡提示database disk image is malformed它的产生有很多种可能,比如,磁盘空间不足,还有就是写入数据过程中突 ...
- 一致性算法--Raft
分布式一致性算法--Raft 前面一篇文章讲了Paxos协议,这篇文章讲它的姊妹篇Raft协议,相对于Paxos协议,Raft协议更为简单,也更容易工程实现.有关Raft协议和工程实现可以参考这个链接 ...
- 转: sublime text 2 前端编码神器-快捷键与使用技巧介绍
代码编辑器或者文本编辑器,对于程序员来说,就像剑与战士一样,谁都想拥有一把可以随心驾驭且锋利无比的宝剑,而每一位程序员,同样会去追求最适合自己的强大.灵活的编辑器,相信你和我一样,都不会例外. 如果说 ...
- GDB调试精粹及使用实例
一:列文件清单 1. List (gdb) list line1,line2 二:执行程序 要想运行准备调试的程序,可使用run命令,在它后面可以跟随发给该程序的任何参数,包括标准输入和标准输出说明符 ...
- java学习之实现文件的复制
package com.io; import java.io.*; import java.text.SimpleDateFormat; import java.util.Date; /** * 文件 ...
- Pick-up sticks(判断两直线相交)
Pick-up sticks Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 11335 Accepted: 4250 D ...