题目地址:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&category=12&problem=951&mosmsg=Submission+received+with+ID+12045188

忒恶心了,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?的更多相关文章

  1. [算法练习] UVA-10010-Where's Waldorf?

    UVA Online Judge 题目10010 Where's Waldorf?  Waldorf在哪? 问题描述: 给出一个m行n列的字符矩阵(),和一个单词列表,在矩阵上匹配每个单词.在矩阵上匹 ...

  2. 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 ...

  3. uva 1354 Mobile Computing ——yhx

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABGcAAANuCAYAAAC7f2QuAAAgAElEQVR4nOy9XUhjWbo3vu72RRgkF5

  4. UVA 10564 Paths through the Hourglass[DP 打印]

    UVA - 10564 Paths through the Hourglass 题意: 要求从第一层走到最下面一层,只能往左下或右下走 问有多少条路径之和刚好等于S? 如果有的话,输出字典序最小的路径 ...

  5. UVA 11404 Palindromic Subsequence[DP LCS 打印]

    UVA - 11404 Palindromic Subsequence 题意:一个字符串,删去0个或多个字符,输出字典序最小且最长的回文字符串 不要求路径区间DP都可以做 然而要字典序最小 倒过来求L ...

  6. UVA&&POJ离散概率与数学期望入门练习[4]

    POJ3869 Headshot 题意:给出左轮手枪的子弹序列,打了一枪没子弹,要使下一枪也没子弹概率最大应该rotate还是shoot 条件概率,|00|/(|00|+|01|)和|0|/n谁大的问 ...

  7. UVA计数方法练习[3]

    UVA - 11538 Chess Queen 题意:n*m放置两个互相攻击的后的方案数 分开讨论行 列 两条对角线 一个求和式 可以化简后计算 // // main.cpp // uva11538 ...

  8. 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 ...

  9. UVA - 1625 Color Length[序列DP 代价计算技巧]

    UVA - 1625 Color Length   白书 很明显f[i][j]表示第一个取到i第二个取到j的代价 问题在于代价的计算,并不知道每种颜色的开始和结束   和模拟赛那道环形DP很想,计算这 ...

  10. UVA - 10375 Choose and divide[唯一分解定理]

    UVA - 10375 Choose and divide Choose and divide Time Limit: 1000MS   Memory Limit: 65536K Total Subm ...

随机推荐

  1. 解决IIS7运行ASP提示错误:An error occurred on the server when processing the URL. Please contact the system administrator

    原文:解决IIS7运行ASP提示错误:An error occurred on the server when processing the URL. Please contact the syste ...

  2. TRS_WCM(拓尔思信息技术有限公司)内容协作平台平台置标经验攻略

    TRS_WCM置标过程中经验积累 版本V4.0-2014.6.24-穿越者7号 目录 1.嵌套模板置标 1 2.栏目名称超链接置标 1 3.列表循环输出文档标题包含超链接 1 4.取既定栏目下第一篇文 ...

  3. EditPlus仿Sublime配色方案(三种任你选择)

    [Options] Placement=2C00000002000000030000000083FFFF0083FFFFFFFFFFFFFFFFFFFFEA000000EE000000D6050000 ...

  4. OpenSUSE 13.2安装Texlive2014+Texmaker+Lyx

    (1)首先下载安装Texlive2014 地址:http://mirrors.ustc.edu.cn/CTAN/systems/texlive/Images/ 或直接下载: wget http://m ...

  5. solr的安装与配置

    solr的安装与配置 不久之前开发了一个项目,需要用到solr,因为所以在开始再网上查找资料,但是发现大部分的资料都是很片面的,要么就是只讲解solr如何安装的,要么就是只讲解solr的某一个部分的, ...

  6. 同TTX更可爱的层次分析法游戏破解

    最近的工作太忙,没啥时间写文章,今天遇到一点点的游戏,浅析.以中午的优势写这篇文章. 移动MM的游戏.前面我们已经写过非常多文章,没有看过的朋友,自行查找就可以,今天我们继续分析一个类似的游戏,只是使 ...

  7. Protocol Buffer和JSON性能比较

      JSON PB 数据结构支持 简单结构 较复杂结构 数据格式 文本 二进制 数据大小 一般 小,json大小的1/3左右 解析效率 一般 快,是json解析速度的3-10倍 可读性 好,自描述的 ...

  8. ext日期加减任意天数

    1.Ext.util.Format.date(new Date().add(Date.DAY, 5), 'Y-m-d'), 'Y-m-d') 2.Ext.util.Format.date(new Da ...

  9. 对Extjs中store的多种操作

    Store.getCount()返回的是store中的所有数据记录,然后使用for循环遍历整个store,从而得到每条记录. 除了使用getCount()的方法外,还可以使用each()函数,如下面的 ...

  10. SpringMVC类型转换、数据绑定

    SpringMVC类型转换.数据绑定详解[附带源码分析] 目录 前言 属性编辑器介绍 重要接口和类介绍 部分类和接口测试 源码分析 编写自定义的属性编辑器 总结 参考资料 前言 SpringMVC是目 ...