算法题:求一个序列S中所有包含T的子序列(distinct sub sequence)
题:
给定一个序列S以及它的一个子序列T,求S的所有包含T的子序列。例:
解:
一、求S的子序列
void PrintDistinctSubByFlags(char* seq, int seq_len, bool* seq_flags)
{
printf("\r\n");
char buf[] = " ";
for (int i = ; i < seq_len; ++i)
{
if (seq_flags[i])
{
buf[] = seq[i];
printf(buf);
}
}
} void DistinctSubInner(char* seq, int seq_len, bool* seq_flags, int seq_flags_idx)
{
if (seq_flags_idx >= seq_len)
{
PrintDistinctSubByFlags(seq, seq_len, seq_flags);
return;
} seq_flags[seq_flags_idx] = false;
DistinctSubInner(seq, seq_len, seq_flags, seq_flags_idx + );
seq_flags[seq_flags_idx] = true;
DistinctSubInner(seq, seq_len, seq_flags, seq_flags_idx + );
} void DistinctSub(char* whole_seq)
{
if(!whole_seq || !*whole_seq)
{
return;
} bool* seq_flags = new bool[strlen(whole_seq) + ];
DistinctSubInner(whole_seq, strlen(whole_seq), seq_flags, );
delete seq_flags;
}
void DistinctSubInner(char* whole_seq, char* sub_seq, int sub_seq_len)
{
if (!*whole_seq)
{
PrintDistinctSub(sub_seq_len);
return;
} sub_seq[sub_seq_len] = *whole_seq;
DistinctSubInner(whole_seq + , sub_seq, sub_seq_len + ); // output head of S
DistinctSubInner(whole_seq + , sub_seq, sub_seq_len); // not ouput head of S
} void DistinctSub(char* whole_seq)
{
if(!whole_seq || !*whole_seq)
{
return;
} sub_seq = new char[strlen(whole_seq)];
DistinctSubInner(whole_seq, sub_seq, );
delete sub_seq;
}
二、求S中所有包含T的子序列
void DistinctSubInner(char* whole_seq, char* min_seq, char* sub_seq, int sub_seq_len)
{
if (!*whole_seq)
{
if(!*min_seq)
{
PrintDistinctSub(sub_seq, sub_seq_len);
}
else
{
// unmatch sub sequence
}
return;
} sub_seq[sub_seq_len] = *whole_seq; if (*whole_seq == *min_seq)
{
// 1. output head of S and match head of T
DistinctSubInner(whole_seq + , min_seq + , sub_seq, sub_seq_len + );
} // 2. output head of S but do not match head of T
DistinctSubInner(whole_seq + , min_seq, sub_seq, sub_seq_len + ); // 3. do not ouput head of S
DistinctSubInner(whole_seq + , min_seq, sub_seq, sub_seq_len);
} void DistinctSub(char* whole_seq, char* min_seq)
{
if(!whole_seq || !*whole_seq || !min_seq || !*min_seq)
{
return;
} char* sub_seq = new char[strlen(whole_seq) + ];
DistinctSubInner(whole_seq, min_seq, sub_seq, );
delete sub_seq;
}
三、去重
3.1 是否需要匹配不同位置?
void DistinctSubInner(char* whole_seq, int sub_seq_len)
{
if (!*whole_seq)
{
if(!*min_seq)
{
PrintDistinctSub(sub_seq_len);
}
return;
} sub_seq[sub_seq_len] = *whole_seq; if (*whole_seq == *min_seq)
{
DistinctSubInner(whole_seq + , min_seq + , sub_seq_len + );
}
else
{
DistinctSubInner(whole_seq + , min_seq, sub_seq_len + );
} DistinctSubInner(whole_seq + , sub_seq_len);
}
3.2 如何解决连续相同元素造成的重复解?
void DistinctSubInner(char* whole_seq, int sub_seq_len)
{
if (!*whole_seq)
{
if(!*min_seq)
{
PrintDistinctSub(sub_seq_len);
}
return;
} sub_seq[sub_seq_len] = *whole_seq; if (*whole_seq == *min_seq)
{
DistinctSubInner(whole_seq + , min_seq + , sub_seq_len + );
}
else
{
DistinctSubInner(whole_seq + , min_seq, sub_seq_len + );
} if(sub_seq[sub_seq_len] != sub_seq[sub_seq_len - ])
{
DistinctSubInner(whole_seq + , min_seq, sub_seq_len);
}
}
int main(int argc, _TCHAR* argv[])
{
char* whole_seqs[] = {
"",
"",
"",
"",
"",
"",
"",
"",
"",
"",}; for (int i = ; i < sizeof(whole_seqs) / sizeof(char*); ++i)
{
printf("\r\n\r\ndistinct sub sequence of \"%s\" for \"%s\" : ===============", whole_seqs[i], "");
DistinctSub(whole_seqs[i], "");
} getchar();
}
后话
算法题:求一个序列S中所有包含T的子序列(distinct sub sequence)的更多相关文章
- 动态规划求一个序列的最长回文子序列(Longest Palindromic Substring )
1.问题描述 给定一个字符串(序列),求该序列的最长的回文子序列. 2.分析 需要理解的几个概念: ---回文 ---子序列 ---子串 http://www.cnblogs.com/LCCRNblo ...
- Expm 10_2 实现Ford-Fulkerson算法,求出给定图中从源点s到汇点t的最大流,并输出最小割。
package org.xiu68.exp.exp10; import java.util.ArrayDeque; import java.util.ArrayList; import java.ut ...
- 求一个集合S中m个元素的所有排列以及一个数组A的全排列—递归实现版完整代码
说明,本文全文代码均用dart语言实现. 求一个集合S中m个元素的所有排列情况,并打印,非常适合用递归的思路实现.本文给出了两种实现方法,一种是给定的填充排列数组长度是固定的,一种是可变长度的.两种方 ...
- Excel-判断一个文本字符串中是否包含数字! 判断一个文本字符串是否是纯汉字!
0.判断一个文本字符串中是否包含数字!/判断一个文本字符串是否是纯汉字! 公式=IF(LENB(A1)=2*LEN(A1),"都是汉字","含有非汉字字符") ...
- 从一道算法题实现一个文本diff小工具
众所周知,很多社区都是有内容审核机制的,除了第一次发布,后续的修改也需要审核,最粗暴的方式当然是从头再看一遍,但是编辑肯定想弄死你,显然这样效率比较低,比如就改了一个错别字,再看几遍可能也看不出来,所 ...
- [java大数据面试] 2018年4月百度面试经过+三面算法题:给定一个数组,求和为定值的所有组合.
给定一个数组,求和为定值的所有组合, 这道算法题在leetcode应该算是中等偏下难度, 对三到五年工作经验主要做业务开发的同学来说, 一般较难的也就是这种程度了. 简述经过: 不算hr面,总计四面, ...
- hdu 1394 求一个序列的最小逆序数 单点增 区间求和
题目的意思就好比给出一个序列 如:0 3 4 1 2 设逆序数初始n = 0: 由于0后面没有比它小的,n = 0 3后面有1,2 n = 2 4后面有1,2,n = 2+2 = 4: 所以该序列逆序 ...
- 设计一个算法,求非空二叉树中指定的第k层(k>1)的叶子节点的个数
思想:採用基于层序遍历的方法. 用level扫描各层节点,若某一层的节点出队后.rear指向该层中最右节点.则将rear赋值给last(对于第一层.last=1).在出队时,若front=last,表 ...
- 一道算法题加深我对C++中map函数的理解
一.一道题目引发我对map函数的考量 首先是题目大意:有n个银行,a[i]表示这个人在第i个银行有a[i]块钱(可以是负数),所有银行的钱加起来正好是0.每次只能在相邻的银行之间转账,问最少要转多少次 ...
随机推荐
- 由浅入深了解EventBus:(一)
概述 由greenrobot织贡献(该组织还贡献了greenDAO),一个Android事件发布/订阅轻量级框架; EventBus是一个消息总线,以观察者模式实现,用于简化程序的组件.线程通信,可以 ...
- 【zznu-2093】毁掉这颗二叉树
题目描述 广寒宫下有株二叉树,树上共有n个节点,通过n-1条树枝连接,树下有一只玉兔,吴刚提着斧子站在一旁. 他恼恨一切同他争夺嫦娥的事物,所以他决定通过砍二叉树上的n-1条树枝来毁掉这颗二叉树. 妙 ...
- 消除浏览器对input输入框的自动填充
Mozilla官方文档建议的是 直接使用 autocomplete = ‘off’ 即可禁止输入框从浏览器cache获取数据,博主以前使用这个也就足够兼容浏览器了. 现在发现,却在chrome.fir ...
- SQL事务的四种隔离级别和MySQL多版本并发控制
SQL标准定义了4类隔离级别,包括了一些具体规则,用来限定事务内外的那些改变时可见的,那些是不可见的.低级别的隔离级一般支持更高的并发处理,并拥有更低的系统开销. ReadUncommitted( ...
- Inception 初探
1,安装 下载组件 wget clone https:/github.com/mysql-inception/inception.git rz ll unzip inception-master.zi ...
- 如何查看PHP的配置信息
1.问题描述 如何利用PHP函数查看PHP的配置信息 2.问题函数 <?php echo phpinfo(); ?> 3.输出结果 phpinfo() PHP Version => ...
- redis事务浅析
事务可以简单理解为:把多件事当做一件事情处理,要么一起成功,要么一起失败.在Spring中可以配置一个事务管理器,然后在要进行事务处理的方法上添加@Transactional注解就可以了. 对于red ...
- [置顶]
Android Glide传Context引发的非法参数异常那些小坑
今天中午调试一直出现nullContext 我的代码如下 解决办法: Glide.with(mContext) .load(mdl.getImage()) .centerCrop() .placeho ...
- NamedParameterJdbcTemplate常用方法总结
数据库结构 1.插入/修改/删除数据,使用update方法 插入数据1 API: int update(String sql, Map< String, ? > paramMap) 示例: ...
- Kotlin都转正成Android官方语言了,你还不试一下?
想想Android Studio 和Eclipse ,我觉得你还是有必要入手Kotlin了. 站好队很重要. 以前的一篇总体概括老文,大家可以看看~ 爽翻天!告别Java.一起来使用kotlin开发完 ...