前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Python急转弯-3-面试篇

Python急转弯-3-面试篇

作者头像
小团子
发布2019-07-18 15:46:13
3310
发布2019-07-18 15:46:13
举报
文章被收录于专栏:数据云团数据云团

经过两轮的头脑爆炸,越是找不到解题思路了。用什么样的方式来答题,才能拿到 offer.这种感受就像是突然之间被电了一下。

① 两个栈实现队列

题目:用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。

有两个栈stackA、stackB,A是入栈的,B是出栈的,入栈时,直接进入A即可,出栈时,先判断是否有元素,如果B没有元素,pop肯定报错,应该先将A中所有的元素压到B里面,再pop最上面一个元素,如果B中有就直接pop出,就可以,两个栈实现了先进后出,在一起又实现了队列的先进先出。

代码语言:javascript
复制
class Solution:
    def __init__(self):
        self.stackA = []
        self.stackB = []

    def push(self, node):
        self.stackA.append(node)

    def pop(self):
        if self.stackB:
            return self.stackB.pop()
        elif not self.stackA:
            return None
        else:
            while self.stackA:
                self.stackB.append(self.stackA.pop())
            return self.stackB.pop()

② 字符串的排列

题目:输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。

依次取一个元素,然后依次和之前递归形成的所有子串组合,形成新的字符串。

代码语言:javascript
复制
class Solution:
    def permutation(self, li):
        # write code here
        if not len(li):
            return []
        if len(li) == 1:
            return list(li)

        charList = list(li)
        print(charList)
        charList.sort()
        pStr = []
        for i in range(len(charList)):
            if i > 0 and charList[i] == charList[i-1]:
                continue
            temp = self.permutation(''.join(charList[:i])+''.join(charList[i+1:]))
            for j in temp:
                pStr.append(charList[i]+j)
                print(pStr)
        return pStr
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-05-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 数据云团 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档