91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python環形單鏈表的約瑟夫問題詳解

發布時間:2020-10-21 11:44:52 來源:腳本之家 閱讀:152 作者:冬日新雨 欄目:開發技術

題目:

一個環形單鏈表,從頭結點開始向后,指針每移動一個結點,就計數加1,當數到第m個節點時,就把該結點刪除,然后繼續從下一個節點開始從1計數,循環往復,直到環形單鏈表中只剩下了一個結點,返回該結點。

這個問題就是著名的約瑟夫問題。

代碼:

首先給出環形單鏈表的數據結構:

class Node(object):
 def __init__(self, value, next=0):
  self.value = value
  self.next = next # 指針

class RingLinkedList(object):
 # 鏈表的數據結構
 def __init__(self):
  self.head = 0 # 頭部

 def __getitem__(self, key):
  if self.is_empty():
   print 'Linked list is empty.'
   return
  elif key < 0 or key > self.get_length():
   print 'The given key is wrong.'
   return
  else:
   return self.get_elem(key)

 def __setitem__(self, key, value):
  if self.is_empty():
   print 'Linked list is empty.'
   return
  elif key < 0 or key > self.get_length():
   print 'The given key is wrong.'
   return
  else:
   return self.set_elem(key, value)

 def init_list(self, data): # 按列表給出 data
  self.head = Node(data[0])
  p = self.head # 指針指向頭結點
  for i in data[1:]:
   p.next = Node(i) # 確定指針指向下一個結點
   p = p.next # 指針滑動向下一個位置
  p.next = self.head

 def get_length(self):
  p, length = self.head, 0
  while p != 0:
   length += 1
   p = p.next
   if p == self.head:
    break
  return length

 def is_empty(self):
  if self.head == 0:
   return True
  else:
   return False

 def insert_node(self, index, value):
  length = self.get_length()
  if index < 0 or index > length:
   print 'Can not insert node into the linked list.'
  elif index == 0:
   temp = self.head
   self.head = Node(value, temp)
   p = self.head
   for _ in xrange(0, length):
    p = p.next
   print "p.value", p.value
   p.next = self.head
  elif index == length:
   elem = self.get_elem(length-1)
   elem.next = Node(value)
   elem.next.next = self.head
  else:
   p, post = self.head, self.head
   for i in xrange(index):
    post = p
    p = p.next
   temp = p
   post.next = Node(value, temp)

 def delete_node(self, index):
  if index < 0 or index > self.get_length()-1:
   print "Wrong index number to delete any node."
  elif self.is_empty():
   print "No node can be deleted."
  elif index == 0:
   tail = self.get_elem(self.get_length()-1)
   temp = self.head
   self.head = temp.next
   tail.next = self.head
  elif index == self.get_length()-1:
   p = self.head
   for i in xrange(self.get_length()-2):
    p = p.next
   p.next = self.head
  else:
   p = self.head
   for i in xrange(index-1):
    p = p.next
   p.next = p.next.next

 def show_linked_list(self): # 打印鏈表中的所有元素
  if self.is_empty():
   print 'This is an empty linked list.'
  else:
   p, container = self.head, []
   for _ in xrange(self.get_length()-1): #
    container.append(p.value)
    p = p.next
   container.append(p.value)
   print container

 def clear_linked_list(self): # 將鏈表置空
  p = self.head
  for _ in xrange(0, self.get_length()-1):
   post = p
   p = p.next
   del post
  self.head = 0

 def get_elem(self, index):
  if self.is_empty():
   print "The linked list is empty. Can not get element."
  elif index < 0 or index > self.get_length()-1:
   print "Wrong index number to get any element."
  else:
   p = self.head
   for _ in xrange(index):
    p = p.next
   return p

 def set_elem(self, index, value):
  if self.is_empty():
   print "The linked list is empty. Can not set element."
  elif index < 0 or index > self.get_length()-1:
   print "Wrong index number to set element."
  else:
   p = self.head
   for _ in xrange(index):
    p = p.next
   p.value = value

 def get_index(self, value):
  p = self.head
  for i in xrange(self.get_length()):
   if p.value == value:
    return i
   else:
    p = p.next
  return -1

然后給出約瑟夫算法:

 def josephus_kill_1(head, m):
  '''
  環形單鏈表,使用 RingLinkedList 數據結構,約瑟夫問題。
  :param head:給定一個環形單鏈表的頭結點,和第m個節點被殺死
  :return:返回最終剩下的那個結點
  本方法比較笨拙,就是按照規定的路子進行尋找,時間復雜度為o(m*len(ringlinkedlist))
  '''
  if head == 0:
   print "This is an empty ring linked list."
   return head
  if m < 2:
   print "Wrong m number to play this game."
   return head
  p = head
  while p.next != p:
   for _ in xrange(0, m-1):
    post = p
    p = p.next
   #print post.next.value
   post.next = post.next.next
   p = post.next
  return p

分析:

我采用了最原始的方法來解決這個問題,時間復雜度為o(m*len(ringlinkedlist))。
但是實際上,如果確定了鏈表的長度以及要刪除的步長,那么最終剩余的結點一定是固定的,所以這就是一個固定的函數,我們只需要根劇M和N確定索引就可以了,這個函數涉及到了數論,具體我就不細寫了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

赤峰市| 定边县| 大城县| 神木县| 泽库县| 报价| 福贡县| 莫力| 炎陵县| 堆龙德庆县| 曲阜市| 都昌县| 赞皇县| 宜城市| 循化| 株洲市| 临江市| 平乐县| 金平| 婺源县| 定结县| 甘孜| 北川| 云和县| 定远县| 明光市| 盐城市| 七台河市| 诏安县| 新巴尔虎左旗| 封开县| 沁阳市| 绍兴县| 龙胜| 扶绥县| 开化县| 石柱| 佛山市| 哈巴河县| 福泉市| 绥中县|