博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数据结构 字符串(一) 全在其中
阅读量:3959 次
发布时间:2019-05-24

本文共 1307 字,大约阅读时间需要 4 分钟。

数据结构(七)

学习数据结构与算法过程中的心得体会以及知识点的整理,方便我自己查找,也希望可以和大家一起交流。

—— 全在其中 ——

1.题目描述

你设计了一个新的加密技术,可以用一种聪明的方式在一个字符串的字符间插入随机的字符串从而对信息进行编码。由于专利问题,我们将不会详细讨论如何在原有信息中产生和插入字符串。不过,为了验证你的方法,有必要写一个程序来验证原来的信息是否全在最后的字符串之中。

给定两个字符串s和t,你需要判断s是否是t的“子列”。也就是说,如果你去掉t中的某些字符,剩下字符将连接而成为s。

1.1输入

输入包括多个测试样例。每一个都是由空格分隔的由字母数字ASCII字符组成的两个特定的字符串s和t。s和t的长度不超过100000。

1.2输出

对于每个测试样例,如果s是t的“子列”,则输出”Yes”,否则输出”No”

1.3样例输入与输出

样例输入

sequence subsequence
person compression
VERDI vivaVittorioEmanueleReDiItalia
caseDoesMatter CaseDoesMatter
样例输出
Yes
No
Yes
No

2.代码实现

c

#include
#include
int main(){
char str_s[100001],str_t[100001]; while(scanf("%s %s",str_s,str_t) != EOF) {
int length_s=strlen(str_s),length_t=strlen(str_t),num=0,strlong=0; for(int i=0;i

c++

#include
#include
using namespace std;char str_s[100001],str_t[100001];bool judge(char * s, char * t){
while(*s != '\0' && *t != '\0'){
while(*t != *s){
t++; if(*t == '\0') return false; } s++,t++; } return *s == '\0';}int main(){
while(scanf("%s%s",str_s,str_t) != EOF){
if(strlen(str_s) > strlen(str_t)) puts("No"); else if(judge(str_s,str_t)) puts("Yes"); else puts("No"); } return 0;}

3.代码说明

这道题的基本思路就是将字符串s的每个字符与字符串t的每个字符进行对比,需要注意的是在s中的一个字符对比结束后,若在t中有相同的字符,则s中下一个字符比对从该字符的位置开始;若在t中没有相同的字符,则直接输出“No”。

转载地址:http://xfazi.baihongyu.com/

你可能感兴趣的文章
Google App engine 的第一个应用 midispot
查看>>
提问的智慧
查看>>
关于dom4j无法解析xmlns问题及生成非UTF-8字符集乱码问题的解决
查看>>
很好的一篇文章 如果让我重做一次研究生 王汎森
查看>>
保护U盘批处理文件
查看>>
hibernate 自动导入sql 文件import.sql 国际化编码的问题的解决方案
查看>>
第七颗头骨 & 忘魂花 凤凰
查看>>
李小龙哲学之言
查看>>
潜伏中体现的潜规则
查看>>
[Java] Appfuse 源代码分析
查看>>
[Java] Appfuse 最佳实践
查看>>
[心情] 如果有一天
查看>>
[随笔] 6月近况小记 & 一个站点优化问题
查看>>
[Perl] 关于 Bugzilla 的一些问题与研究
查看>>
[Linux] 常用 linux 系统命令及维护备忘
查看>>
[Linux] 关于 Ext4 HowTo
查看>>
[杂记] 新年物语&关于Mysql引擎性能测试
查看>>
[心得] 近期更新&关于Infobright
查看>>
[杂记] 流量统计 & 短信接口
查看>>
[Java] JRebel + Maven + Jetty 热部署
查看>>