剑指offer-字符的所有组合,复制复杂链表,二叉树中和为某一值的路径
字符的所有组合
描述:
输入一个字符串,求这个字符串中的字符的所有组合。如:“abc”,组合为"a" "b" c" "ab" "ac" "bc" "abc"
思路:
对于n个字符,求长度为m的组合,将字符分为两部分,对于当前的字符,要么取,然后再n-1个字符中取m-1个,要么不取,在n-1个字符中取m个。
代码:
void combination(string s, int num, vector<char>res);
void combination(string s)
{
if (s.empty())
return;
vector<char> res;
int number = s.size();
for (int i = 1; i <= number; i++) //组合长度
{
combination(s,i, res);
}
}
void combination(string s, int num, vector<char>res)
{
if (num == 0) //递归出口
{
static int n = 1;
cout << "这是第" << n << "个组合" << endl;
n++;
vector<char>::iterator it;
for (it = res.begin(); it != res.end(); it++)
{
cout << *it;
}
cout << endl;
return;
}
if (s.size() == 0)
return ;
res.push_back(s[0]);
s = s.assign(s,1, s.size() - 1);
combination(s, num - 1, res); //要么加入这个字符,在接下来的字符串中找num-1个字符
res.pop_back();
combination(s, num , res); // 要么不加入这个字符,在接下来的字符串中找num个字符。
}
复制复杂链表
描述:
复制一个复杂的链表,链表节点除了next指针,还有随机的指针指向NULL或任意节点。
思路:
分解问题。第一步,在每个节点后复制一个原节点,并用next链接。第二步,链接随机指针,每个复制的节点的随即指针的指向都是前一个节点的随机指针指向的节点的后一个节点。
最后,分离链表。
代码:
struct CpxListNode
{
int v;
CpxListNode* next;
CpxListNode* sibing;
};
void CloneNodes(CpxListNode* head)
{
CpxListNode* p = head;
while (p)
{
CpxListNode* cp = new CpxListNode;
cp->v = p->v;
cp->sibing = NULL;
cp->next = p->next;
p->next = cp;
p = cp->next;
}
}
void ConnectSibing(CpxListNode* head)
{
CpxListNode* p = head;
while(p)
{
CpxListNode* cp = p->next;
if(p->sibing)
cp->sibing = p->sibing->next;
p = cp->next;
}
}
CpxListNode* ReConnect(CpxListNode* head)
{
CpxListNode* chead=NULL;
CpxListNode* p=head;
CpxListNode* cp = NULL;
if (p)
{
chead = p->next;
cp = chead;
}
while (p)
{
p->next = cp->next;
p = p->next;
cp->next = p->next;
cp = cp->next;
}
return chead;
}
CpxListNode* CopyCL(CpxListNode* head)
{
CloneNodes(head); //将复制后的节点插入原节点后面
ConnectSibing(head); //sibing指针的处理
return ReConnect(head); //分离链表
}
二叉树中和为某一值的路径
描述:
对于给定值k,要求在二叉树中找到一条路径,路径上的节点值和为k。
思路:
先序遍历整个树,用栈来记录路径,采用递归的思想,当走到一个节点,当前的和为num,若它是叶子节点,则找到一条路径。否则再从它的左右子树中找。
代码:
void Findpath(TreeNode* root, int num, vector<int> path, int currentsum)
{
currentsum += root->v;
path.push_back(root->v);
if ((currentsum == num) && (root->left == NULL && root->right == NULL))
{
cout << "FIND" << endl;
for (int i = 0; i < path.size(); i++)
{
cout << path[i];
}
}
else
{
if (root->left != NULL)
{
Findpath(root->left, num, path, currentsum);
}
if (root->right)
{
Findpath(root->right, num, path, currentsum);
}
/*currentsum -= root->v;
path.pop_back();*/
//这边不用对currentsum和path操作,因为它们作为变量传入,返回时自动恢复,如果它们作为静态变量,则需要手动恢复。
}
}
void FindInTree(TreeNode* root, int num)
{
if (root == NULL)
{
return;
}
int currcentsum = 0;
vector<int> path;
Findpath(root, num, path, currcentsum);
}
剑指offer-字符的所有组合,复制复杂链表,二叉树中和为某一值的路径的更多相关文章
- 【剑指Offer面试题】 九度OJ1368:二叉树中和为某一值的路径
题目链接地址: http://ac.jobdu.com/problem.php? pid=1368 题目1368:二叉树中和为某一值的路径 时间限制:1 秒内存限制:32 兆特殊判题:否提交:2252 ...
- 【剑指Offer面试编程题】题目1368:二叉树中和为某一值的路径--九度OJ
题目描述: 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. 输入: 每个测试案例包括n+1行: 第一行为2 ...
- 《剑指offer》第三十四题(二叉树中和为某一值的路径)
// 面试题34:二叉树中和为某一值的路径 // 题目:输入一棵二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所 // 有路径.从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. #i ...
- 《剑指offer》 合并两个排序的链表
本题来自<剑指offer> 合并两个排序的链表 题目: 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. 思路: A:采用递归的方式(C++ C ...
- 剑指offer 二叉树中和为某一个值的路径
剑指offer 牛客网 二叉树中和为某一个值的路径 # -*- coding: utf-8 -*- """ Created on Tue Apr 9 15:53:58 2 ...
- 剑指Offer - 九度1368 - 二叉树中和为某一值的路径
剑指Offer - 九度1368 - 二叉树中和为某一值的路径2013-11-23 03:46 题目描述: 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结 ...
- 剑指Offer:二叉树中和为某一值的路径【34】
剑指Offer:二叉树中和为某一值的路径[34] 题目描述 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. ...
- 剑指Offer:合并两个排序的链表【25】
剑指Offer:合并两个排序的链表[25] 题目描述 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. 题目分析 每次都是比较箭头节点,把小节点连接到已经合 ...
- 剑指Offer(二十四):二叉树中和为某一值的路径
剑指Offer(二十四):二叉树中和为某一值的路径 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.ne ...
随机推荐
- java进阶视频分享
更多资源和教程请关注公众号:非科班的科班. 如果觉得我写的还可以请给个赞,谢谢大家,你的鼓励是我创作的动力 课程目录介绍 01.开班仪式02.并发编程专题之多线程基础03.并发编程专题之Java内存模 ...
- 《代码整洁之道》&《程序员的职业素养》
这是why技术的第32篇原创文章 春节期间读了两本技术相关的书籍:编程大师Bob大叔的<代码整洁之道>和<代码整洁之道:程序员的职业素养>. <代码整洁之道>出版于 ...
- php编译完php.ini加载问题-Loaded Configuration File (none)
编译安装php7时指定了--with-config-file-path=/usr/local/php7/etc,修改了 php.ini 的配置后重启,但就是不生效. 出现Loaded Configur ...
- Centos7搭建FastFDS----分布式文件服务系统服务端
一.FastDFS介绍 FastDFS开源地址:https://github.com/happyfish100 参考:分布式文件系统FastDFS设计原理 参考:FastDFS分布式文件系统 1.1简 ...
- 数据结构与算法 --- js描述队列
js描述队列 队列的特性是只能在队尾插入元素,在队首删除元素,先进先出: 队列被用在很多地方,比如提交操作系统执行的一系列进程,打印任务池,模拟现实中的排队: //队列类 function Queue ...
- larabel Artisan Command 使用总结
larabel Artisan Command 使用总结 定义命令 在routes/console.php下定义命令 Artisan::command('ltf', function () { (ne ...
- php--->底层的运行机制与数据结构原理
PHP 底层的运行机制与数据结构原理 1. PHP的设计理念及特点 多进程模型:由于PHP是多进程模型,不同请求间互不干涉,这样保证了一个请求挂掉不会对全盘服务造成影响,当然,随着时代发展,PHP也早 ...
- Web自动化测试项目(四)测试报告
测试报告生成 使用HTMLTestRunner 生成测试报告 本文使用的 HTMLTestRunner 来源于github: https://github.com/githublitao/HTMLTe ...
- Linux(Centos)安装tomcat并且部署Java Web项目
步骤一.下载安装包 a. 下载tomcat linux安装包,地址:http://tomcat.apache.org/download-80.cgi , 我们下载的版本是8.0,下载方式如图: b ...
- nodejs爬虫第一篇---> request、cheerio实现小爬虫
目标 抓取猫眼正在热映的电影页面的数据,使用的第三方模块 request.cheerio. 说明 有时候我们需要做一些项目或者demo,我们需要一些数据,我们就可以利用爬虫,爬取一些我们想要的数据.个 ...