待字闺中之interleave字符串分析

题目来源,待字闺中,原创@陈利人 ,欢迎大家继续关注微信公众账号“待字闺中”

3个字符串a,b,c。判断c是否是a和b的interleave,也就是c中应该有a,b中所有字
符,并且c中字符顺序和a,b中一样。比如,

1. a = "ef" b = "gh" c = "egfh" return true;

2. a = "ef" b = "gh" c = "ehgf" return false。

这个题目中,并没有说明a和b中是否有相同的字符,这个直接影响了最终的解法。所以,大家在面试的过程中,要和面试官进行交互,弄清楚之后再动手。我们这里对于是否有相同的字符都给予分析。希望对大家有所帮助。

a和b没有相同字符的情况

这个情况处理起来比较简单,逐个字符遍历c字符串,首先处理第一个字符,将其与a中的字符匹配,如果没有匹配,则与b中的字符逐个匹配,如果没有匹 配,则返回false;如果a中或者b中有一个字符和c的第一个字符匹配上了,则如上考虑第二个字符,与c的第一个字符匹配上的字符串,也考虑第二个字 符,依次类推。直到c遍历完,这时,如果a和b还有字符没有遍历,也返回false,都遍历完毕,返回true。代码如下:

bool interleave_diff(const char* a,const char* b,const char* c)
{
	int lenA = strlen(a),lenB = strlen(b),lenC = strlen(c);
	if(lenA + lenB != lenC)return false;
	int i = 0,j = 0,k = 0;
	while(c[k] != '\0')
	{
		if(a[i] == c[k]) i++;
		else if(b[j] == c[k]) j++;
		else return false;
		k++;
	}
	if(a[i] != '\0' || b[j] != '\0')return false;
	return true;
}

a和b有相同字符的情况

上面的算法,不能够处理a和b中有相同字符的情况,例如a="XXY",b="XXZ",c="XXZXXY"。如果要处理,有相同字符的情况也是 比较直接的。有相同的出现,如果都匹配了c中的字符,则两种匹配分别都考虑,只要有一个返回true,整个算法就返回true。

所以,下面介绍一个动态规划的解法。一个问题能够用动态规划来解的一个前提是:要有重复的子 问题。这样把子问题的解存储起来,后面重复利用才可以提高算法的效率。这个问题有子问题么?考虑一个极端的例 子:a="XXX",b="XXX",c="XXXXXX"。子问题,显然存在。再不然,画出递归树,就很明了了。

我们采用二维表来存储子问题的结果,dp[i][j]如果为true,则表示c[0..i+j-1]是a[0..i-1]和b[0..j-1]的interleave字符串。算法实现的过程于上面的递归类似:

bool interleave_same(const char* a,const char* b,const char* c)
{
	int lenA = strlen(a),lenB = strlen(b),lenC = strlen(c);
	if(lenA + lenB != lenC)return false;
	bool dp[lenA+1][lenB+1];
	int i,j;
	for( i = 0;i <= lenA;i++)
	{
		for(j = 0;j <= lenB;j++)
		{
			if( i == 0 && j == 0)dp[i][j] = true;
			else if( i == 0) dp[i][j] = (b[j-1] == c[i+j-1]) && dp[i][j-1];
			else if( j == 0) dp[i][j] = (a[i-1] == c[i+j-1]) && dp[i-1][j];
			else dp[i][j] = ((a[i-1] == c[i+j-1]) && dp[i-1][j]) || ((b[j-1] == c[i+j-1]) && dp[i][j-1]);//状态转移方程式
		}
	}
	return dp[lenA][lenB];
}

如有问题,请指正,谢谢

待字闺中之interleave字符串分析

时间: 2024-08-26 01:57:04

待字闺中之interleave字符串分析的相关文章

待字闺中之逆序分析

题目来源,待字闺中,原创@陈利人 ,欢迎大家继续关注微信公众账号"待字闺中" 一个整数,可以表示为二进制的形式,请给出尽可能多的方法对二进制进行逆序操作. 例如:10000110 11011000的逆序为 00011011 01100001 分析:题目中说是一个整数,对它的二进制进行逆序.并不是一个01字符串,或者01的数组.那么我们该如何解决这个问题呢?方法还是比较多的,有的中规中矩.有的非常巧妙.我们要掌握中规中规的方法,见识更多的巧妙的方法.慢慢的,能够举一反三,在遇到新的问题时

待字闺中之构造最大数分析

给定只包含正数的数组,给出一个方法,将数组中的数拼接起来,得到的数,是最大的. 例如: [4, 94, 9, 14, 1] 拼接之后,所得最大数为:9944141 分析 我们可以将两个数字,作为一个整体,进行比较.然后一次排序,就得到了结果.给定例子:5,54,56 比较5和54,实际上就是比较545和554哪个大 比较5和56,实际上就是比较556和565哪个大 比较54和56,实际上就是比较5456和5654哪个大 那我们对快排程序做一下变化,当两个数字a和b进行比较时,比较的是ab和ba两

待字闺中之Magic Index 分析

给定一个数组A,其中有一个位置被称为Magic Index,含义是:如果i是Magic Index,则A[i] = i.假设A中的元素递增有序.且不重复,请给出方法,找到这个Magic Index.更进一步,当A中允许有重复的元素,该怎么办呢? 没有重复元素的情况 一些同学在遇到这个题目的时候,往往会觉得比较简单.扫描一遍,不就ok了么?O(n)的.很简单呀.可是,大家要注意到,还有一个条件没有用:A中的元素是有序递增的.这个条件,并不是放在这里迷惑大家的,而是有更大的作用的.这个时候,该如何想

待字闺中之死亡小岛分析

一个小岛,表示为一个N×N的方格,从(0,0)到(N-1, N-1),一个人站在岛上,位置(x, y),他可以上下左右走,一步一个格子,他选择上下左右的可能性是一样的.当他走出小岛,就意味着死亡.假设他要走n步,请问他死亡的概率有多大?请写出求解代码. 分析 遇到这样的问题,就试着走几步好了.当一个人在(x,y)的时候,假设他此时,死亡的概率为p(x,y,n),然后,他有四种选择,而且是可能性相同,就是说,选择上下左右的概率都是1/4: 选择上边,死亡的概率是多少呢?此时位置为(x, y-1),

待字闺中之相伴一生分析

题目来源,待字闺中,原创@陈利人 ,欢迎大家继续关注微信公众账号"待字闺中" 原题 给定一个数组,数组中只包含0和1.请找到一个最长的子序列,其中0和1的数量是相同的. 例1:10101010 结果就是其本身. 例2:1101000 结果是110100 请大家展开自己的思路. 分析 这个题目,看起来比较简单,一些同学可能认为题目的描述符合动态规划的特征,然后就开始用动态规划解,努力找状态转移方程.这些同学的感觉,是很正确的.但,找状态转移方程,我们要对原来的数组进行变换一下. 原来是0

MATLAB的字符串分析

MATLAB的字符串分析. 字符串实际上是指1Xn 的字符数组. MATLAB软件具有强大的字符串处理功能,提供了很多的字符或字符串处理函数,包括字符串的创建.字符串的属性.比较.查找以及字符串的转换和执行等. 由于MATLAB语言是用C语言进行开发的,因此它的字符串操作与C语言的相应操作非常类似. 字符串操作的常用函数: % 字符串处理 a='  a';b='b  b';c='cccc';m='' % 获取字符串长度 length(a) % 连接两个字符串,每个字符串最右边的空格被裁切 d=s

剑指offer之寻找丑数,待字闺中之序列生成分析

题目来源:剑指offer之寻找丑数 与 待字闺中之序列生成分析 两个题目其实是同一个问题,所有放在一起,算是总结一下,题目如下: 给定一个表达式2^i*2^j,其中i,j为非负整数.请找到一种方法,生成如下序列: 2^0 * 5^0 = 1 2^1 * 5^0 = 2 2^2 * 5^0 = 4 2^0 * 5^1 = 5 2^3 * 5^0 = 8 2^1 * 5^1 = 10 2^4 * 5^0 = 16 2^2 * 5^1 = 20 2^0 * 5^2 = 25 ... ... ... 阅

逆向中静态分析工具——IDA初学者笔记之字符串分析

逆向中静态分析工具--IDA初学者笔记之字符串分析 程序中往往包含很多字符串资源,这些资源存在于PE文件的rdata段,使用IDA反编译后,可以查找到这些字符串, 逆向破解程序通常需要一个突破点,而这个突破点,往往就是一个Messagebox,因为这个Messagebox可以很直观的 让我们知道当前位置的代码负责哪些功能,而同时Messagebox可以提供一个字符串让我们来查找定位. 首先,打开IDA,主菜单View-Open subviews-strings: 这时出来一个strings窗口,

String中字符串==分析

目录 String中字符串==分析 new String intern() 通过字面量赋值 常量字符串 "+" 对于final字段 变量和常量字符串拼接 参考博客 String中字符串==分析 new String new String都是在堆上创建字符串对象. intern() 调用intern()方法时,编译器会将字符串添加到常量池中(StringTable维护),并返回指向该常量的引用. String str2 = new String("str")+new