寄居蟹与海葵
来源:互联网 发布:北京php培训学校 编辑:程序博客网 时间:2024/04/29 19:47
描述
寄居蟹与海葵是一对合作互助的共栖伙伴。海葵是寄居蟹最称职的门卫。它用有毒的触角去蜇那些敢来靠近它们的所有动物,保护寄居蟹。而寄居蟹则背着行动困难的海葵,四出觅食,有福同享。
但并不是所有寄居蟹和海葵都可以做搭档的。那就要看海葵的身体是不是符合寄居蟹的螺壳。
海葵的身体是有褶皱的,而寄居蟹的螺壳同样凹凸不平,我们可以用一个大写字母组成的字符串来表示它们的高低程度,其中A代表0,B代表1,依次类推。我们称两者相加等于25的就算是吻合,比如A和Z相吻合,B与Y吻合,依次类推。
只要海葵身体的部分序列与寄居蟹外壳的序列相吻合,就称他们可以一起生活。
比如:
1.海葵的褶皱是"ABCDEFG",寄居蟹是"ZYXWVUT"。这样,它们就可以完全吻合了。
2.海葵的褶皱是"AHBICJDKELFMGN",寄居蟹是"ZYXWVUT"。这样,寄居蟹可以和海葵的部分序列"ABCDEFG"相吻合 (注意:部分序列不改变字符原来的先后顺序,比如"ACB"就不是它的部分序列)。
3.海葵的褶皱是"ABCD",寄居蟹是"ZYXWVUT"。这样,虽然海葵可以和寄居蟹前面一段完全吻合,但它比寄居蟹要小,不能完全保护寄居蟹的安全,所有它们是不适合的。
4.海葵的褶皱是"HIJKLMNOPQ",寄居蟹是"ZYXWVUT"。这样,它们就可以完全不吻合了。
现给你两段字符串S1、S2,分别代表海葵和寄居蟹的外壳,为了它们以后各都能快乐地生活,请你帮忙计算一下它们是不是吻合的。
输入
输入包括多组测试数据。
每组测试数据包括两个字符串H、J,分别代表海葵的外壳和寄居蟹的外壳。可以保证它们的长度都小于100000。
输入以0 0结束。
输出
如果寄居蟹和海葵的外壳能吻合,就输出"Yes",否则输出"No"。
样例输入
AHBICJDKELFMGN ZYXWVUT
ABCD ZYXWVUT
HIJKLMNOPQ ZYXWVUT
0 0
样例输出
Yes
No
No
#include<iostream>using namespace std;int match(char h[],char j[],int len1,int len2){ int i,s=0,n; for(i=0,n=0;i<len1 && n<len2;n++){ if(h[n]-65+j[i]-65==25){ s++; i++; } } return s;}int main(){ char h[100000],j[100000]; int hlen,jlen,i; while(cin>>h>>j && (strcmp(h,"0") || strcmp(h,"0"))) { hlen=strlen(h); jlen=strlen(j); if(hlen<jlen){ cout<<"No\n"; continue; } else { if(match(h,j,jlen,hlen)==jlen) cout<<"Yes\n"; else cout<<"No\n"; } } return 0;}
- 寄居蟹与海葵
- 寄居蟹与海葵
- 寄居蟹与海葵
- 寄居蟹与海葵
- 寄居蟹与海葵
- 寄居蟹与海葵
- 寄居蟹与海葵
- 寄居蟹与海葵
- oj1904: 寄居蟹与海葵
- 寄居蟹与海葵
- ytu1904——寄居蟹与海葵
- OJ刷题之《寄居蟹与海葵》
- 寄居蟹和海葵
- 寄居蟹
- 代码的寄居蟹
- 与
- 与
- “” 与 “”
- onNewIntent调用时机
- 在IE8下解决无法调用迅雷下载的问题
- linux更改执行进程名称
- 最牛B的编码套路
- virtualBox中安装ubuntu重启异常问题
- 寄居蟹与海葵
- 深入分析java web 技术内幕_笔记_六
- 热酷发“檄文”起诉云中游 法院已受理
- 用python实现八皇后
- myeclipse不编译的情况
- CRM上线之路 走上了CRM实施顾问-第122天上班 -第25周
- UVa 694 Collatz序列
- C语言字节对齐
- 有关hibernate的缓存机制