【剑指offer】字符串的组合

转载请注明出处:http://blog.csdn.net/ns_code/article/details/26405471


剑指offer上的拓展题目,输入一个字符串,输出该字符串的字符的所有组合,比如输入字符串:abc,输出a、b、c、ab、ac、bc、abc。

思路:与上一题类似,也可以用递归求解。可以考虑求长度为n的字符串中m个字符的组合,设为C(n,m)。原问题的解即为C(n, 1), C(n, 2),...C(n, n)的总和。对于求C(n, m),从第一个字符开始扫描,每个字符有两种情况,要么被选中,要么不被选中,如果被选中,递归求解C(n-1, m-1)。如果未被选中,递归求解C(n-1, m)。不管哪种方式,n的值都会减少,递归的终止条件n=0或m=0。

博主是刚开始尝试用递归去写,写了一个多小时都没写出来,桑心啊!除了操作二叉树写递归比较顺,其他好多地方用递归愣是憋不出来,尤其字符串操作。

在何海涛博客下看到有人留言,给了个思路,觉得很不错,自己把代码写了出来。具体思路如下:

开辟一个于字符串对应长度的int数组(char数组也可以,而且更节省空间),用该数组模拟二进制的加1操作,则该数组的元素只能为0或1,我们规定如果该数组某个位置处的元素是1,则字符串对应位置处的字符参与组合,如果为0,则字符串对应位置处的字符不参与组合,这样讲该int数组,从全0加到全1,便可得到字符串的全部组合。

这里没有去除重复子串,也没按照字典序输出,如果要求按照字典序输出,并去掉重复子串的话,可以采取上道题目一样的办法,先将所有的字符串保存在字符串数组中,而后通过快排使数组中的字符串按照字典序排列,再在输出的时候,跳过重复的字符串。

实现代码如下:

#include<stdio.h>
#include<string.h>
#include<stdlib.h>

/*
模拟二进制加1操作,当最高位要进位时,说明所有的位都是1,返回false,
用char数组来模拟比int数组更省空间,这里必须传入数组长度len,
由于我们CominationAll中将要传入的字符数组全部初始化为了‘\0‘,
如果在该函数内部用strlen计算的话,会得到len=0。
*/
bool Increment(char *BindAdd,int len)
{
	if(BindAdd == NULL)
		return false;

	BindAdd[len-1]++;
	int i;
	for(i=len-1;i>=0;i--)
	{
		if(BindAdd[i] >= 2)
		{
			if(i == 0)
			{
				BindAdd[i]--;
				return false;
			}
			else
			{
				BindAdd[i] -= 2;
				BindAdd[i-1]++;
			}
		}
		else
			break;
	}
	return true;
}

/*
输出字符串的所有组合
*/
void CominationAll(char *str)
{
	if(str == NULL)
		return;

	int len = strlen(str);
	char *BindAdd = (char *)malloc(len*sizeof(char));
	if(BindAdd == NULL)
		exit(EXIT_FAILURE);

	memset(BindAdd,0,len*sizeof(char));
	while(Increment(BindAdd,len))
	{
		int i;
		for(i=0;i<len;i++)
		{
			if(BindAdd[i] == 1)
				putchar(str[i]);
		}
		putchar(‘\n‘);
	}

	free(BindAdd);
	BindAdd = NULL;
}

int main()
{
	char str[10];
	while(gets(str))
		CominationAll(str);
	return 0;
}

测试结果:

【剑指offer】字符串的组合,布布扣,bubuko.com

时间: 2024-08-08 01:16:06

【剑指offer】字符串的组合的相关文章

剑指offer—字符串转换整数

对于这个问题, 本题考查的实际上就是字符串转换成整数的问题,或者说是要你自行实现atoi函数.那如何实现把表示整数的字符串正确地转换成整数呢?以"345"作为例子: 当我们扫描到字符串的第一个字符'3'时,由于我们知道这是第一位,所以得到数字3. 当扫描到第二个数字'4'时,而之前我们知道前面有一个3,所以便在后面加上一个数字4,那前面的3相当于30,因此得到数字:3*10+4=34. 继续扫描到字符'5','5'的前面已经有了34,由于前面的34相当于340,加上后面扫描到的5,最终

[剑指offer] 字符串的顺序全排列

题目描述 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba. 结果请按字母顺序输出. 输入描述 输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母. 输出描述 顺序输出字符串的所有排列 题目分析 这是一个字符串全排列的问题,把全部序列存在TreeSet中默认可得到字典顺序. TreeSet 基于TreeMap实现的SortedSet,可以对Set集合中的元

《剑指offer》面试题28:字符串排序(牛客网版本) java

题目描述 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba. 输入描述: 输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母. 这里尤其需要注意2点:1.所有组合不能重复,比如输入"aa",  那么输出的结果应当是"aa" : 2. 输出结果按字典序排序 如果用<剑指offer>上的方法,显然这两点都不能满足,比如

【剑指offer】字符串的排列

转载请注明出处:http://blog.csdn.net/ns_code/article/details/26390551 题目描述: 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba. 输入: 每个测试案例包括1行. 输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母. 输出: 对应每组数据,按字典序输出所有排列. 样例输入: abc BCA 样例输出:

剑指offer (49) 字符串转数字

class Test { public: Test() : n2(0), n1(n2 + 2) { } private: int n1; int n2; }; 调用构造函数之后,n1个n2各为多少? 分析:构造函数的初始化顺序仅仅取决于成员变量的声明顺序,所以这是 应该是 n1先初始化,然后是n2初始化 当n1初始化值 = n2值 + 2,此时n2并没有初始化,n2为内置类型并且是non-static,所以n2此时为随机值 故 n1 为随机值,n1初始完之后,n2初始化为0 最终 n1为随机值,

【剑指offer】左旋转字符串

转载请注明出处:http://blog.csdn.net/ns_code/article/details/27366485 题目描述: 汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果.对于一个给定的字符序列S,请你把其循环左移K位后的序列输出.例如,字符序列S="abcXYZdef",要求输出循环左移3位后的结果,即"XYZdefabc".是不是很简单?OK,搞定它! 输入: 多组测试数据,每个测试数据包含一个

【剑指offer】字符串转整数

转载请注明出处:http://blog.csdn.net/ns_code/article/details/28015693 题目描述: 将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数. 输入: 输入可能包含多个测试样例.对于每个测试案例,输入为一个合法或者非法的字符串,代表一个整数n(1<= n<=10000000). 输出: 对应每个测试案例,若输入为一个合法的字符串(即代表一个整数),则输出这个整数.若输入为一个非法的字符串,则输出"My God". 样

170319 剑指offer 1.把一个字符串转化成整数(简单问题的全面性考虑)

工作的时间越长,越感觉基础的重要性,当我们对程序的框架结构越来越熟悉的时候,越会注意这一点,在工作当中,功能的实现是重要的,但是代码的健壮性,重用性,与扩展性确往往更为重要,在学习新技术的同时,我们或许应该抽出一点时间,去思考代码可能出现的问题. 关于剑指offer的这本书,可能所有刚毕业找工作的人,或者准备找工作的人都曾经看过,但是当时我们面对一些东西的时候心情过于浮躁,往往忽视了简单的却又十分重要的环节,(ps:也可能只有我是这样) 面试中一道简单的问题(把一个字符串转化成整数) 可能接触c

剑指offer之【表示数值的字符串】

题目: 表示数值的字符串 链接: https://www.nowcoder.com/practice/6f8c901d091949a5837e24bb82a731f2?tpId=13&tqId=11206&rp=3&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking 题目描述: 请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如,字符串"+100",&quo