算法题:求一个序列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.每次只能在相邻的银行之间转账,问最少要转多少次 ...
随机推荐
- 010PHP基础知识——运算符(三)
<?php /** * 位运算符: * 1:&按位与:左右两边的数,同位都为1,返回是1,否则返回是0 */ /*$a = 5; $b = 6; $a = decbin($a);//10 ...
- C++复习5.指针数组字符串
C/C++ 指针.数组和字符串 本次学习指针.数组.字符串.引用的内存映像. 1.指针 指针的本质:可以执行的程序是由指令.数据和地址组成的.当CPU访问内存单元的时候,不论是读取还是写入,首先要把内 ...
- Spark安装和简单示例
spark的安装 先到官网下载安装包 注意第二项要选择和自己hadoop版本相匹配的spark版本,然后在第4项点击下载.若无图形界面,可用windows系统下载完成后传送到centos中. 本例中安 ...
- bzoj3623
题解: 刚看到题目,还以为是2-sat 可是似乎不对啊... 然后就只能爆搜了 看了网上的题解,woc还真是报搜 然后就ac了 当然爆搜还要随机化 代码: #include<bits/stdc+ ...
- LeetCode OJ:Implement Queue using Stacks(栈实现队列)
比较典型的一个题目,easy,不过可以有许多实现方式. 这里用的方式是每次pop完成之后再将stack2中的内容立即倒回stack1中.但是其他的实现也可以不是这样,可以是需要push的时候检查再,如 ...
- Javascript-- jQuery动画篇(2)
动画效果 前面的 hide/show,slide in/out 其实也具有动画效果,本篇介绍使用 animate()实现自定义动画效果. 基本语法如下: $(selector).animate({pa ...
- 关于php print_r
print_r (PHP 4, PHP 5, PHP 7) print_r — 打印关于变量的易于理解的信息. 描述¶ bool print_r ( mixed $expression [, bool ...
- React之事件处理
在react中,事件处理的写法和处理方式可能会和vue以及传统html有些不同. 一.事件名和默认行为阻止 事件名采用驼峰写法,并且方法名用大括号引入,而不是双引号: <button onCli ...
- python3精简笔记(三)——高级特性
Python中 1行代码能实现的功能,决不写5行代码.请始终牢记,代码越少,开发效率越高. 切片 取一个list或tuple的部分元素是非常常见的操作.Python提供了切片(Slice)操作符 L ...
- 从零开始编写深度学习库(五)PoolingLayer 网络层CPU编写
记录:编写卷积层和池化层,比较需要注意的细节就是边界问题,还有另外一个就是重叠池化的情况,这两个小细节比较重要,边界问题pad在反向求导的时候,由于tensorflow是没有计算的,另外一个比较烦人的 ...