1501 Zipper
2015-09-07 22:18
363 查看
ZipperTime Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 7417 Accepted Submission(s): 2622 Problem Description Given three strings, you are to determine whether the third string can be formed by combining the characters in the first two strings. The first two strings can be mixed arbitrarily, but each must stay in its original order. For example, consider forming "tcraete" from "cat" and "tree": String A: cat String B: tree String C: tcraete As you can see, we can form the third string by alternating characters from the two strings. As a second example, consider forming "catrtee" from "cat" and "tree": String A: cat String B: tree String C: catrtee Finally, notice that it is impossible to form "cttaree" from "cat" and "tree". Input The first line of input contains a single positive integer from 1 through 1000. It represents the number of data sets to follow. The processing for each data set is identical. The data sets appear on the following lines, one data set per line. For each data set, the line of input consists of three strings, separated by a single space. All strings are composed of upper and lower case letters only. The length of the third string is always the sum of the lengths of the first two strings. The first two strings will have lengths between 1 and 200 characters, inclusive. Output For each data set, print: Data set n: yes if the third string can be formed from the first two, or Data set n: no if it cannot. Of course n should be replaced by the data set number. See the sample output below for an example. Sample Input 3 cat tree tcraete cat tree catrtee cat tree cttaree Sample Output Data set 1: yes Data set 2: yes Data set 3: no |
#include <iostream> #include <stdio.h> #include <string.h> #include <string> #include <vector> #include <algorithm> #include <stdlib.h> using namespace std; #define M 220 int n; bool flag; char s1[M]; char s2[M]; char s3[M*2]; int len1, len2, len3; void DFS(int x, int y, int z){ if(flag) return; if(z >= len3){ flag = true; return ; } if(s1[x] == s3[z]) DFS(x+1,y,z+1); if(s2[y] == s3[z]) DFS(x,y+1,z+1); return; } int main(){ scanf("%d",&n); for(int i = 1; i <= n; i++){ memset(s1,0,sizeof(s1)); memset(s2,0,sizeof(s2)); memset(s3,0,sizeof(s3)); scanf("%s%s%s",s1,s2,s3); len1 = strlen(s1); len2 = strlen(s2); len3 = strlen(s3); flag = false; if(s1[len1-1] == s3[len3-1] || s2[len2-1] == s3[len3-1]){ DFS(0,0,0); } if(flag) printf("Data set %d: yes\n",i); else printf("Data set %d: no\n",i); } return 0; }
相关文章推荐
- Reverse Integer
- Javascript邮箱增删
- OpenCV 读取摄像头并显示图像的R、G、B三个通道的直方图
- 快速排序Python实现
- 两个贷款计算器
- iOS开发:MVC(模型-视图-控制器)详解
- 操作系统 之 fork 函数 概念篇
- 哈夫曼(huffman)树和哈夫曼编码
- HDU--1074(状态压缩DP)
- 自动装箱(boxing)和自动拆箱(unboxing)
- Linux操作系统桌面环境GNOME和KDE的切换
- jquery插件网站推荐
- UVALive 6625_状态压缩
- DOM优化
- 在数码管上静态显示键值
- UIScrollView和UIPageControl结合
- Volley框架简介
- Longest Palindromic Substring
- javascript输入验证
- android shape的使用