思路:回溯

  • 树的左指针表示(,树的右指针表示),分别用leftright计数,如果left < num,那么允许走左边;如果left > right,那么允许走右边。每个节点一共两个分支。
  • ss.pop_back()体现了回溯的思想,否则不会往上走。
  • image.png

代码:

  1. class Solution {
  2. public:
  3. void dfs(int n, int cur_index, vector<string>& res, string& ss, int left, int right) {
  4. if (cur_index == 2 * n) {
  5. res.push_back(ss);
  6. return;
  7. }
  8. if (left < n) {
  9. ss.push_back('(');
  10. dfs(n, cur_index + 1, res, ss, left + 1, right);
  11. ss.pop_back();
  12. }
  13. if (right < left) {
  14. ss.push_back(')');
  15. dfs(n, cur_index + 1, res, ss, left, right + 1);
  16. ss.pop_back();
  17. }
  18. }
  19. vector<string> generateParenthesis(int n) {
  20. vector<string> res;
  21. string ss;
  22. dfs(n, 0, res, ss, 0, 0);
  23. return res;
  24. }
  25. };