猿问

堆栈和队列亚马逊面试问题

描述


给定一个包含 n 个整数的数组 A。您必须创建一个给定整数的队列和堆栈。队列应仅包含素数,堆栈应仅包含合数。数组中的所有数字都是 。形成堆栈和队列的规则是您应该能够使用弹出和出队操作生成数组。注:请仔细阅读本说明


假设数组 A 包含 5 个整数: 7 , 21 , 18 , 3 , 12 ,那么队列和堆栈的内容将为: 队列 : 7 , 3 堆栈 : 12 , 18 , 21 现在,如果您遵循堆栈和队列的规则,那么您会发现可以使用堆栈的弹出操作和队列的出列操作来生成数组,如下所示:


dequeue from queue : 7

pop from stack : 7 , 21

pop from stack : 7 , 21 , 18

dequeue from queue : 7 , 21 , 18 , 3

pop from stack : 7 , 21 , 18 , 3 , 12

因此,对于每个数组 A,您必须在第一行中打印队列的内容,在第二行中打印堆栈的内容。


输入格式 第一行包含一个整数 n 作为输入,表示数组中整数的总数。下一行包含 n 个空格分隔的整数,表示数组 A 的元素。您的输出应打印两个 array ,每行一个。第一行应该是队列的内容,第二行应该是堆栈的内容。


输出格式 第一行打印队列的内容,第二行打印堆栈的内容。


样本输入


5

7 21 18 3 12

样本输出


7 3 

12 18 21 

我的代码


backwas = input()

num1 = list(map(int, input().split()))

dic = {}


for num in num1:

    output = []

    for i in range(2,num+1):

        if num%i == 0:

            output.append(i)

        for item in set(output):

            output1 = list(set(output))

            dic[num] = output1

prime = []

comp = []


for num in num1:

    list1 = []

    list1 = list(dic[num])

    if len(list1) != 1:

        comp.append(str(num))

    else:

        prime.append(str(num))

   

print(" ".join(prime))

print(" ".join(comp))

我的代码有问题


如果你读得正确,你会立即注意到这个问题的困难部分是以正确的顺序创建两个列表,也就是说,当对它们进行一些操作时,它们会返回原始列表。我的代码无法做到这一点。我应该如何解决这个问题?


慕神8447489
浏览 138回答 2
2回答

呼啦一阵风

问题的要点要求给定一系列空格分隔的整数,将列表分为存储在队列中的素数和存储在堆栈中的复合整数。按 FIFO 顺序输出队列中的素数,并按 LIFO 顺序输出堆栈中的复合整数。队列是线性先进先出 (FIFO) 数据结构。如果我们使用append()来实现enqueue(),使用pop()来实现dequeue(),那么List数据结构就可以用作队列。然而,列表为此目的非常慢,因为在开头插入或删除元素需要 O(n) 时间。使用集合 mnodule 中的出队类是首选队列实现机制,因为追加和弹出操作需要 O(1) 时间。堆栈是线性后进/先出 (LIFO) 或先入/后出 (FILO) 数据结构。与队列类似,列表数据结构可以用来实现堆栈,但是与队列情况一样,如果列表很长,就会出现性能问题。因此,出队类是实现堆栈的首选。根据指令,第一行输入给出第二行输入中的整数个数。第二行由空格分隔的整数组成。输出由两行组成。第一个输出行应按照输入的顺序显示输入中的素数。第二行应以与输入相反的顺序显示输入中的合数。这是我解决问题的方法:#Utility to detect a Primedef is_prime(n: int) -> bool:&nbsp; &nbsp; """&nbsp; &nbsp; &nbsp;Integer -> Boolean&nbsp; &nbsp; &nbsp;returns True if n is a prime number&nbsp; &nbsp; """&nbsp; &nbsp; if n == 2 or n == 3: return True&nbsp; &nbsp; if n < 2 or n%2 == 0: return False&nbsp; &nbsp; if n < 9: return True&nbsp; &nbsp; if n%3 == 0: return False&nbsp; &nbsp; r = int(sqrt(n))&nbsp; &nbsp; f = 5&nbsp; &nbsp; while f <= r:&nbsp; &nbsp; &nbsp; &nbsp; if n%f == 0:&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; return False&nbsp; &nbsp; &nbsp; &nbsp; if n%(f+2) == 0:&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; return False&nbsp; &nbsp; &nbsp; &nbsp; f +=6&nbsp; &nbsp; return True使用列表方法# Implementation with Lists assuming instr is list of integersdef list_method(instr: str):&nbsp; &nbsp; qlist = []&nbsp; &nbsp; stklist = []&nbsp; &nbsp; inLst = list(map(lambda x:int(x) ,instr.split()))&nbsp; &nbsp; for n in inLst:&nbsp; &nbsp; &nbsp; &nbsp; if is_prime(n):&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; qlist.append(n)&nbsp; &nbsp; &nbsp; &nbsp; else:&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; stklist.append(n)&nbsp; &nbsp; print(" ".join(map(lambda x: str(x), qlist)))&nbsp; &nbsp; print(" ".join(map(lambda x: str(x), stklist[::-1])))使用出队类from collections import dequedef queue_method(instr: str):&nbsp; &nbsp; q = deque()&nbsp; &nbsp; stk = deque()&nbsp; &nbsp; inLst = list(map(lambda x:int(x) ,instr.split()))&nbsp; &nbsp; for n in inLst:&nbsp; &nbsp; &nbsp; &nbsp; if is_prime(n):&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; q.append(n)&nbsp; &nbsp; &nbsp; &nbsp; else:&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; stk.append(n)&nbsp; &nbsp; print(" ".join([str(q.popleft()) for i in range(len(q))]))&nbsp; &nbsp; print(" ".join([str(stk.pop()) for i in range(len(stk))]))

蝴蝶刀刀

这是使用埃拉托斯特尼筛法和 2 个数组的简单方法。num1 = [7,21,18,3,12]&nbsp; &nbsp; # your listn = max(num1)prime = [True for i in range(n+1)]&nbsp;p = 2while (p * p <= n):&nbsp; #creating a Sieve using standard operations&nbsp; &nbsp; if (prime[p] == True):&nbsp;&nbsp; &nbsp; &nbsp; &nbsp; for i in range(p * p, n+1, p):&nbsp;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; prime[i] = False&nbsp; &nbsp; p += 1prim, comp = [], []for i in num1:&nbsp; &nbsp; if prime[i]:&nbsp; &nbsp; &nbsp; &nbsp; prim.append(i)&nbsp; &nbsp; else:&nbsp; &nbsp; &nbsp; &nbsp; comp.append(i)for i in prim:&nbsp; &nbsp; print(i, end = " ")print()for i in comp[::-1]:&nbsp; &nbsp; print(i, end = " ")print()
随时随地看视频慕课网APP

相关分类

Python
我要回答