【搜狐笔试】显示所有正确的括号匹配

个人主页:http://guanzi.info

原文链接:http://guanzi.info/?p=21


题目:

编程实现所有括号的合法匹配。实例如下:

输入 3

输出 ((())) (()()) (())() ()(()) ()()()


解题思路:

学名为:深度优先搜索(DFS) 这是看别人的文章得到的名称。。。

代码如下:

#include "stdafx.h"
#include "iostream"
#include "stdio.h"
#include <vector>
#include <string>

using namespace std;

void func(int left, int right , vector<char>& str){
	if( left != 0 ){
		str.push_back( '(' );
		func( left-1, right, str);
		str.pop_back();
	}
	if ( right  != 0){
		if ( left < right){
			str.push_back( ')' );
			func( left, right-1, str);
			str.pop_back();
		}
	}
	if ( right == 0 ){
		for( int i = 0; i < str.size(); i++)
			cout << str[i];
		cout << endl;
	}
	return;
}

int main( ){
	int n;
	vector<char> str;
	cin >> n;
	func( n, n, str);
	return 1;
}


程序运行状态解释如下:

输入  3

函数调用栈如下

step1:

         func(3,3) push(       “(”            调用func(2, 3)

step2:

         func(2,3) push (      “((”           调用func(1, 3)

         func(3,3)

step3:

         func(1,3) push (     “(((”         调用func(0, 3)

         func(2,3)

         func(3,3)

step4:

         func(0,3) push)      “((()”       调用func(0, 2)

         func(1,3)

         func(2,3)

         func(3,3)

...此处不再赘述

step7:

         func(0,0) print       “((()))”      return

         func(0,1)

         func(0,2)

         func(0,3)

         func(1,3)

         func(2,3)

         func(3,3)

接下来这一步是看懂这个递归的重点

step8:

         func(0,1) pop         “((())”       return

         func(0,2)

         func(0,3)

         func(1,3)

         func(2,3)

         func(3,3)

step9:

         func(0,2) pop         “((()”         return

         func(0,3)

         func(1,3)

         func(2,3)

         func(3,3)

step10:

         func(0,3) pop         “(((”         return

         func(1,3)

         func(2,3)

         func(3,3)

此处的处理是第二个重点。程序开始第二次遍历

step11:

         func(1,3) pop         “((”                   push)        “(()”         调用func(1, 2)

         func(2,3)

         func(3,3)

step12:

         func(1,2)push(       “(()(”         调用func(0, 2)

         func(1,3)

         func(2,3)

         func(3,3)

此处省略部分步骤

step k:

         func(0,0)print        “(()())”      return

         func(0,1)

         func(0,2)

         func(1,2)

         func(1,3)

         func(2,3)

         func(3,3)

继续省略一些过程

step l:

         func(2,3)pop                  “(”            push)       “()”           调用func(2, 2)

         func(3,3)


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值