第一行输入两个整数
(
,
),分别表示缓存容量和文章单词数。
第二行输入
个整数
(
),表示文章中按顺序出现的单词编码。
输出一个整数,表示翻译过程中缓存未命中(查词典)的总次数。
3 7 1 2 1 5 4 4 1
5
翻译过程示例(缓存状态记录自左向右为最早到最近):
初始:空
1: miss,缓存->[1]
2: miss,缓存->[1,2]
1: hit,缓存->[1,2]
5: miss,缓存->[1,2,5]
4: miss,缓存->[2,5,4](替换1)
4: hit,缓存->[2,5,4]
1: miss,缓存->[5,4,1](替换2)
共 miss 5 次。
class Queue:
def __init__(self):
self.in_stack: list[int] = []
self.out_stack: list[int] = []
def push(self, x: int):
self.in_stack.append(x)
def _dump_if_needed(self):
if not self.out_stack:
while self.in_stack:
self.out_stack.append(self.in_stack.pop())
def pop(self) -> int:
if self.isEmpty():
raise IndexError("pop from an empty queue")
self._dump_if_needed()
return self.out_stack.pop()
def query(self) -> int:
if self.isEmpty():
raise IndexError("pop from an empty queue")
self._dump_if_needed()
return self.out_stack[-1]
@property
def size(self) -> int:
return len(self.in_stack) + len(self.out_stack)
def isEmpty(self) -> bool:
return not self.in_stack and not self.out_stack
def __len__(self) -> int:
return self.size
def __contains__(self, x : int) -> bool:
return x in self.in_stack&nbs***bsp;x in self.out_stack
def totalQuery(M : int, words : list[int]) -> int:
vocab = Queue()
total_number_of_query = 0
for word in words:
if word not in vocab:
total_number_of_query += 1
if vocab.size >= M:
vocab.pop()
vocab.push(word)
return total_number_of_query
def main():
M, N = map(int, input().split())
words = list(map(int, input().split()))
print(totalQuery(M, words))
if __name__ == "__main__":
main() def page_replaced(l,k,pages):
cache = []
missed_count = 0
for page in pages:
if page not in cache:
missed_count += 1
if l == len(cache):
cache.pop(0)
cache.append(page)
return missed_count
l,k = map(int,input().strip().split(" "))
pages = list(map(int,input().strip().split(" ")))
print(page_replaced(l,k,pages))