题解 | #字符串的排列#

字符串的排列

https://www.nowcoder.com/practice/fe6b651b66ae47d7acce78ffdd9a96c7

#include <bits/stdc++.h>
using namespace std;

#include <stack>
class Solution {
  public:
    set<string> res;
    void dfs( string str, string tmp, vector<bool> &vis ) {
        if (tmp.size() == str.size()) {
            res.insert(tmp);
            return;
        }
        for (int i = 0; i < str.length(); i++) {
            //如果未选择
            if (vis[i] == false) {
                vis[i] = true;
                dfs( str,tmp + str[i], vis );
                vis[i] = false;

            }
        }
    }
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param str string字符串
     * @return string字符串vector
     */
    vector<string> Permutation(string str) {

        vector<bool>vis(str.length(),false); 
        vector<string>res_vec;
        dfs(  str, "", vis);

        for (auto it = res.begin(); it != res.end(); it++) {
            res_vec.push_back(*it);
        }
        return res_vec;
    }
};

这牛客啥时候编程和leetcode一样的模式了?

两个问题:

使用vector,不用数组

传参如果需要改变,使用引用传参

可以使用类属性set<string> res;因为它不需要初始化,像 vector<bool>vis(str.length(),false); 需要字符串长度初始化

全部评论

相关推荐

头像
10-22 20:13
中南大学 Java
序言大家好呀。我是希晨er,一个初入职场的程序猿小登最近上班摸鱼刷到了一篇文章:10年深漂,放弃高薪,回长沙一年有感,还有聊聊30岁大龄程序员过往的心路历程,突然就有点感慨。我如今也做出了和大明哥一样的抉择,只是更早。此外我22年的人生,好像从来没好好记录过。正好现在工作不太忙,就想把这些经历写下来,也希望能得到社区里各位前辈的指点个人背景我是03年出生的西安娃,父母都是普通打工人。刚从中南大学软件工程专业毕业半年,现在在老家的央企过着躺平摆烂的日子成长轨迹从农村到城市的童年我家并不是西安的,只是爸妈在西安上班,从小学之后就把我接到了西安。后来老家房子拆了,爷爷奶奶也搬了过来。农村的生活,我觉...
Yki_:看哭了,恋爱那一段你女朋友说你不够关心她,可你毕竟也愿意遇到矛盾写几千字来和她慢慢分析;说不愿意给她花钱,我感觉可能只是消费观不一样;如果她想留在长沙,也应该提前跟你说开。不过她也许会心疼你放弃大厂offer转向数字马力?我也因为同样的原因有过一段幸福而充满遗憾的感情,不过跟爱情相比确实前途更重要一点。至于offer的选择,换我我也会这么选。把这些旧事记录下来以后,接下来就好好向前看吧,加油兄弟
🍊晨光随笔
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务