當前位置: 首頁>>代碼示例>>Python>>正文


Python LinkedList.LinkedList類代碼示例

本文整理匯總了Python中LinkedList.LinkedList的典型用法代碼示例。如果您正苦於以下問題:Python LinkedList類的具體用法?Python LinkedList怎麽用?Python LinkedList使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了LinkedList類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: add_link

def add_link(head1, head2):
    carry = 0
    dummy1 = LinkedList()
    dummy2 = LinkedList()
    dummy1.next = head1
    dummy2.next = head2
    p1 = dummy1
    p2 = dummy2
    while p1.next and p2.next:
        carry += p1.next.val + p2.next.val
        p1.next.val = carry % 10
        carry /= 10
        p1 = p1.next
        p2 = p2.next

    while p1.next:
        carry += p1.next.val
        p1.next.val = carry % 10
        carry /= 10
        p1 = p1.next
    while p2.next:
        carry += p2.next.val
        p1.next = LinkedList(carry % 10)
        carry /= 10
        p1 = p1.next
        p2 = p2.next
    if carry:
        p1.next = LinkedList(carry)

    return dummy1.next
開發者ID:aihex,項目名稱:cracking-the-coding-interview-python,代碼行數:30,代碼來源:Q2.4.py

示例2: Doc

    class Doc():
        def __init__(self, doc):
            self.doc   = doc;
            self.lines = LinkedList();
            self.count = 1;
            self._iterator = None;
            self.documentFrequency = None;
        def reset(self):
            self.lines.reset();
            self._iterator = None;
        def __str__(self):
            return '\n\t' + str(self.doc) + ', count:' + str(self.count) + self.lines.toString(',');
        def __lt__(self, other):
            return self.doc < other.doc;
        def __eq__(self, other):
            return self.doc  == other.doc;

        def insertLine(self, line):
            line = IndexList.Line(int(line));
            self.lines.insertSorted(line);

        def __iter__(self):
            return self;
        def next(self):
            if self._iterator is None:
                if self.lines._head is None: raise StopIteration
                self._iterator = self.lines._head;
                return self._iterator.value;
            self._iterator = self._iterator.next;
            if self._iterator is None: raise StopIteration
            return self._iterator.value;
開發者ID:anconaesselmann,項目名稱:pySearch,代碼行數:31,代碼來源:IndexList.py

示例3: reverse

def reverse(lst):
    reverse_lst = LinkedList()
    cur = lst.head
    while cur is not None:
        reverse_lst.insert(cur.get_key())
        cur = cur.get_next()
    return reverse_lst
開發者ID:prathamtandon,項目名稱:python-algorithms-and-data-structures,代碼行數:7,代碼來源:isPalindrome.py

示例4: LLQueue

class LLQueue(object):
    def __init__(self, size=0):
        self._list = LinkedList()
        self._size = size

    def enqueue(self, data):
        if (self._size > 0 and self._list.count < self._size):
            self._list.add(data)
        else:
            raise Exception("Too many items in the queue")

    def dequeue(self):
        if (self._list.count == 0):
            raise Exception("No items in the queue")
        node = self._list[0]
        del self._list[0]
        return node

    def isEmpty(self):
        return (self._list.count == 0)

    def clear(self):
        self._list.clear()

    @property
    def size(self):
        return self._size

    def __len__(self):
        return len(self._list)
開發者ID:bertothunder,項目名稱:coursera-algorithms,代碼行數:30,代碼來源:LLQueue.py

示例5: sum_list

def sum_list(l1, l2):
  """
  returns a list which contains the addition of input two lists.
  """
  lsum = LinkedList()
  carry = 0
  l1_node = l1.head
  l2_node = l2.head

  while l1_node or l2_node:
    val = carry
    if l1_node:
      val += l1_node.value
      l1_node = l1_node.next

    if l2_node:
      val += l2_node.value
      l2_node = l2_node.next

    lsum.add(val % 10)
    carry = val / 10
  if carry:
    lsum.add(carry)

  return lsum
開發者ID:vivekkeshore,項目名稱:ctci,代碼行數:25,代碼來源:list_sum_2_5.py

示例6: __init__

class Queue:

	def __init__(self):
		self._ls = LinkedList()
		self.size = 0 

	def __str__(self):
		return "Queue contains:{0}".format(self._ls)

	def __iter__(self):
		return self

	def next(self):
		if not self.isEmpty():
			j = self.dequeue()
			return j
		else:
			raise StopIteration()

	def enqueue(self,n):
		self._ls.append(n,None)
		self.size += 1

	def dequeue(self):
		j = self._ls.popHead()
		self.size -= 1
		return j.key

	def isEmpty(self):
		return self.size == 0 

	def show(self):
		self._ls.show()
開發者ID:IoDmitri,項目名稱:Python-Datastructures-and-Algorithims,代碼行數:33,代碼來源:Queue.py

示例7: read_file

def read_file(file):
    '''
    Read CSV File, Important Only Read column 1 and column 2
    
    Parameters
    ----------
    file : str, path of file 
        path for file to read and fill dataset
    
    Returns
    -------
    dataset: LinkedLink dataset
    '''
    #Open File
    with open(file, 'rb') as csvfile:
        reader = csv.reader(csvfile)
        dataset=LinkedList()
        #for row in file:
        for row in reader:
                #if length of row >= 2:
                if len(row) >= 2:
                    #add to LinkedList Float Row[0] and Row[1]
                    try:
                        dataset.add(( float(row[0]) , float(row[1]) ))
                    except ValueError:
                        log.warning("%s Problem whit row" % row[0])
                else:
                    #mesnsaje: row whit insuficient data.
                    log.warning("row whit insuficient data or Empty Row")
        return dataset
開發者ID:arpagon,項目名稱:assignaments,代碼行數:30,代碼來源:fit.py

示例8: add_two_numbers_adding_digit_reverse

def add_two_numbers_adding_digit_reverse(lst1, lst2):
    lst = LinkedList()
    current_1 = lst1.head
    current_2 = lst2.head
    carry = 0

    def get_digit(node1, node2):
        nonlocal carry
        num1 = 0 if node1 is None else node1.get_data()
        num2 = 0 if node2 is None else node2.get_data()
        value = num1 + num2 + carry
        if value >= 10:
            carry = 1
            value %= 10
        else:
            carry = 0
        return value

    current_lst = lst.head

    while current_1 is not None or current_2 is not None or carry > 0:
        digit = get_digit(current_1, current_2)
        lst.insert(digit)
        current_1 = current_1.get_next() if current_1 is not None else None
        current_2 = current_2.get_next() if current_2 is not None else None
    return reverse_list(lst)
開發者ID:ZachLiuGIS,項目名稱:Algorithm-Enthusiasts,代碼行數:26,代碼來源:add_two_numbers.py

示例9: reverse_list

def reverse_list(lst):
    new_lst = LinkedList()
    current = lst.head
    while current:
        new_lst.insert(current.get_data())
        current = current.get_next()
    return new_lst
開發者ID:ZachLiuGIS,項目名稱:Algorithm-Enthusiasts,代碼行數:7,代碼來源:check_palindrome.py

示例10: setUp

    def setUp(self):
        self.lst1 = LinkedList()
        self.lst2 = LinkedList()
        self.common_lst = LinkedList()

        self.lst1.insert(4)
        self.lst1.insert(2)
        self.lst1.insert(5)
        self.lst1.insert(8)
        self.lst1.insert(6)

        self.lst2.insert(3)
        self.lst2.insert(10)
        self.lst2.insert(8)

        self.common_lst.insert(3)
        self.common_lst.insert(2)
        self.common_lst.insert(5)
        self.common_lst.insert(7)

        current = self.lst1.head
        while current.get_next():
            current = current.get_next()
        current.set_next(self.common_lst.head)

        current = self.lst2.head
        while current.get_next():
            current = current.get_next()
        current.set_next(self.common_lst.head)
開發者ID:ZachLiuGIS,項目名稱:Algorithm-Enthusiasts,代碼行數:29,代碼來源:test.py

示例11: test_insert_two

def test_insert_two():
    l_list = LinkedList()
    l_list.insert("David")
    l_list.insert("Thomas")
    assert l_list.head.get_data() == "Thomas"
    head_next = l_list.head.get_next()
    assert head_next.get_data() == "David"
開發者ID:pombredanne,項目名稱:CrackCode,代碼行數:7,代碼來源:TestLinkedList.py

示例12: test_delete

 def test_delete(self):
     x = LinkedList([1,2,3,4,5])
     val1 = x.delete(0)  # 1st element
     val2 = x.delete(-1)  # last element
     self.assertEqual(val1, 1)
     self.assertEqual(val2, 5)
     self.assertEqual(list(x), [2,3,4])
開發者ID:xpspectre,項目名稱:cell-image,代碼行數:7,代碼來源:test_LinkedList.py

示例13: __init__

class Queue:
    def __init__(self):
        self.__elements = LinkedList()

    # Adds an element to this queue
    def enqueue(self, e):
        self.__elements.add(e)
    
    # Removes an element from this queue
    def dequeue(self):
        if self.getSize() == 0:
            return None
        else:
            return self.__elements.removeAt(0)
    
    # Return the size of the queue
    def getSize(self):
        return self.__elements.getSize()
    
    # Returns a string representation of the queue
    def __str__(self):
        return self.__elements.__str__()

    # Return true if queue is empty 
    def isEmpty(self):
        return self.getSize() == 0
開發者ID:EthanSeaver,項目名稱:Python-Projects,代碼行數:26,代碼來源:Queue.py

示例14: testPrepend

def testPrepend():
	my_linked_list = LinkedList()

	for i in range(0,10):
		my_linked_list.prepend(i)

	print my_linked_list
開發者ID:WillYee,項目名稱:LinkedListDemo,代碼行數:7,代碼來源:LinkedListTest.py

示例15: insert

def insert(UI):
	#chop the UI to get only (position,item)
	command = UI[6:]
	#Regular expression: (\(\d*,.\))
	expression = re.compile('(\(\d*,.*\))')
	if (expression.match(command) != None):
		#get the position
		pos = command[1]
		i = 2
		while command[i] != ",":
			pos += command[i]
			i += 1

		#Check that position is a number
			if (~pos.isdigit()):
				break

		#get the item
		item = command[i+1]
		i += 2
		while command[i] != ")":
			item += command[i]
			i += 1

		#called insert with pos, item
		LinkedList.insert(int(pos), item)
開發者ID:aes421,項目名稱:VisualLinkedList,代碼行數:26,代碼來源:Driver.py


注:本文中的LinkedList.LinkedList類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。