UVa-Where's Waldorf?
忒恶心了,UVa不提示格式错误,格式错误直接WA。。。
C++代码:
#include <cstdio>
#include <utility>
#include <cstring>
using namespace std;
char s[100][100];
int m,n;
int len;
bool searchright(int a,int b,char name[])
{
int i=a,j=b;
if(b+len-1>=n)
return false;
for(;j<=b+len-1;++j)
if(s[i][j]!=name[j-b])
return false;
return true;
}
bool searchleft(int a,int b,char name[])
{
int i=a,j=b;
if(b-len+1<0)
return false;
for(;j>=b-len+1;--j)
if(s[i][j]!=name[b-j])
return false;
return true;
}
bool searchup(int a,int b, char name[])
{
int i=a,j=b;
if(a-len+1<0)
return false;
for(;i>=a-len+1;--i)
if(s[i][j]!=name[a-i])
return false;
return true;
}
bool searchdown(int a,int b, char name[])
{
int i=a,j=b;
if(a+len-1>=m)
return false;
for(;i<=a+len-1;++i)
if(s[i][j]!=name[i-a])
return false;
return true;
}
bool searchleftup(int a,int b,char name[])
{
int i=a,j=b;
if((i-len+1<0)||(j-len+1<0))
return false;
for(;i>=a-len+1;--i,--j)
if(s[i][j]!=name[a-i])
return false;
return true;
}
bool searchrightup(int a,int b,char name[])
{
int i=a,j=b;
if((i-len+1<0)||(b+len-1>=n))
return false;
for(;i>=a-len+1;--i,++j)
if(s[i][j]!=name[a-i])
return false;
return true;
}
bool searchleftdown(int a,int b,char name[])
{
int i=a,j=b;
if((i+len-1>=m)||(j-len+1<0))
return false;
for(;i<=a+len-1;++i,--j)
if(s[i][j]!=name[i-a])
return false;
return true;
}
bool searchrighdown(int a,int b,char name[])
{
int i=a,j=b;
if((i+len-1>=n)||(j+len-1>=n))
return false;
for(;i<=a+len-1;++i,++j)
if(s[i][j]!=name[i-a])
return false;
return true;
}
pair<int,int> search(char name[])
{
int i=0,j=0;
for(i=0;i<m;++i)
{
for(j=0;j<n;++j)
{
if(searchleft(i,j,name)||searchright(i,j,name)||searchup(i,j,name)||searchdown(i,j,name)||
searchleftup(i,j,name)||searchrightup(i,j,name)||searchleftdown(i,j,name)||searchrighdown(i,j,name))
goto loop;
}
}
loop:
return make_pair(i,j);
}
int main()
{
char name[100];
int cas;
while(scanf("%d",&cas)!=EOF)
{
while(cas--)
{
scanf("%d%d",&m,&n);
int i,j;
for(i=0;i<m;++i)
{
scanf("%s",s[i]);
for(j=0;s[i][j];++j)
if(s[i][j]>='A'&&s[i][j]<='Z')
s[i][j]=s[i][j]-'A'+'a';
}
int num;
scanf("%d",&num);
while(num--)
{
scanf("%s",name);
for(i=0;name[i];++i)
if(name[i]>='A'&&name[i]<='Z')
name[i]=name[i]-'A'+'a';
len=strlen(name);
pair<int,int> p=search(name);
printf("%d %d\n",p.first+1,p.second+1);
}
if(cas)
printf("\n");
}
}
return 0;
}
UVa-Where's Waldorf?的更多相关文章
- [算法练习] UVA-10010-Where's Waldorf?
UVA Online Judge 题目10010 Where's Waldorf? Waldorf在哪? 问题描述: 给出一个m行n列的字符矩阵(),和一个单词列表,在矩阵上匹配每个单词.在矩阵上匹 ...
- UVA大模拟代码(白书训练计划1)UVA 401,10010,10361,537,409,10878,10815,644,10115,424,10106,465,10494
白书一:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=64609#overview 注意UVA没有PE之类的,如果PE了显示WA. UVA ...
- uva 1354 Mobile Computing ——yhx
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABGcAAANuCAYAAAC7f2QuAAAgAElEQVR4nOy9XUhjWbo3vu72RRgkF5
- UVA 10564 Paths through the Hourglass[DP 打印]
UVA - 10564 Paths through the Hourglass 题意: 要求从第一层走到最下面一层,只能往左下或右下走 问有多少条路径之和刚好等于S? 如果有的话,输出字典序最小的路径 ...
- UVA 11404 Palindromic Subsequence[DP LCS 打印]
UVA - 11404 Palindromic Subsequence 题意:一个字符串,删去0个或多个字符,输出字典序最小且最长的回文字符串 不要求路径区间DP都可以做 然而要字典序最小 倒过来求L ...
- UVA&&POJ离散概率与数学期望入门练习[4]
POJ3869 Headshot 题意:给出左轮手枪的子弹序列,打了一枪没子弹,要使下一枪也没子弹概率最大应该rotate还是shoot 条件概率,|00|/(|00|+|01|)和|0|/n谁大的问 ...
- UVA计数方法练习[3]
UVA - 11538 Chess Queen 题意:n*m放置两个互相攻击的后的方案数 分开讨论行 列 两条对角线 一个求和式 可以化简后计算 // // main.cpp // uva11538 ...
- UVA数学入门训练Round1[6]
UVA - 11388 GCD LCM 题意:输入g和l,找到a和b,gcd(a,b)=g,lacm(a,b)=l,a<b且a最小 g不能整除l时无解,否则一定g,l最小 #include &l ...
- UVA - 1625 Color Length[序列DP 代价计算技巧]
UVA - 1625 Color Length 白书 很明显f[i][j]表示第一个取到i第二个取到j的代价 问题在于代价的计算,并不知道每种颜色的开始和结束 和模拟赛那道环形DP很想,计算这 ...
- UVA - 10375 Choose and divide[唯一分解定理]
UVA - 10375 Choose and divide Choose and divide Time Limit: 1000MS Memory Limit: 65536K Total Subm ...
随机推荐
- IOS被遗忘的知识
IOS ARC项目使用非ARC文件 1.自己的旧项目没有使用ARC,可是引入的第三方库却是使用了ARC的. 对于第一个情况,给採用了ARC的源文件,加入-fobjc-arc选项 2.自己的新项目使用了 ...
- java查找反复类/jar包/普通文件
开发web应用时,有时更新了类却没有生效,事实上是由于jboss/tomcat中其它公布包下有同名类(包含全路径都同样). 于是萌发了做个程序来检查指定文件夹是否存在反复类(通过asm从类文件里取类的 ...
- automake/autoconf的简单例子
参考文章1:http://loftor.com/archives/automake.html 参考文章2:http://www.blogjava.net/huyi2006/articles/18790 ...
- 用批处理编译*.sln工程
原文:用批处理编译*.sln工程 批处理是直接调用Microsoft Visual Studio 8\Common7\IDE\ 目录内的 devenv.exe ,它启动后就是IDE,提供的参数如下: ...
- [译]Java 设计模式之装饰器
(文章翻译自Java Design Pattern: Decorator – Decorate your girlfriend) 1.装饰模式的来历 让我们假设你在寻找一个女朋友.有来自像没美国中国日 ...
- 在Ubuntu中编译QT工程Tesful
今天晚上开机到Ubuntu中了,试了一下之前在Windows下建立的Tesful工程,发现没有任何改动就可以编译成功/运行. 附上图:
- Android高仿雅虎天气(两)---代码结构分析
版本已经升级到1.0.1 源码地址: GitHub:https://github.com/way1989/WayHoo OsChina:http://git.oschina.net/way/WayHo ...
- WinForm中回车键实现文本框之间的跳转
利用窗体的KeyPreView .设置KeyPreView = true 设置窗体的KeyPreView 属性为True后,那么窗体内的子控件响应KeyPress事件(或其他事件)之前,会先响应窗体的 ...
- 处理程序“svc-Integrated”在其模块列表中有一个错误模块“ManagedPipelineHandler”
HTTP 错误 404.3 - Not Found 由于扩展配置问题而无法提供您请求的页面.如果该页面是脚本,请添加处理程序.如果应下载文件,请添加 MIME 映射. 解决办法:以管理员运行命令:C: ...
- jenkins+svn+gradle自动化部署笔记
自己虚拟机jekins配置:(jenkins+svn+gradle)自动化部署,1.linux配置好jdk,解压tomcat,将 jenkins.war翻到webapps目录下.2.系统管理-管理用户 ...