当前位置: 首页>>代码示例>>Golang>>正文


Golang List.MoveAfter方法代码示例

本文整理汇总了Golang中container/list.List.MoveAfter方法的典型用法代码示例。如果您正苦于以下问题:Golang List.MoveAfter方法的具体用法?Golang List.MoveAfter怎么用?Golang List.MoveAfter使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在container/list.List的用法示例。


在下文中一共展示了List.MoveAfter方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。

示例1: SortList

// Sort a linked list. This is a stable sort.
func SortList(List *list.List, f SortLtFunc) {
	var L, R, N, A, T *list.Element
	var sz uint = 1
	var numMerges, Lsz, Rsz uint

	if List.Len() < 2 {
		return
	}

	A = List.Front()
	//Z = List.Back()   (not needed)

	// STABLE
	for {
		// 'A' is either the head of the original list (on the first iteration), or
		// a list whose subdivisions of 2*(sz/2) are sorted. Either way, 'A' is now
		// 'L' and 'A' and 'T' will be used to assemble the next 'generation' of
		// the sorted list.
		numMerges = 0
		L = A
		A = nil
		T = A

		for L != nil {
			numMerges++
			R = L
			Lsz = 0
			Rsz = sz

			// Step R so that we have adjacent but non-overlapping partitions
			//   [L,R)          (range Lsz)
			// and
			//   [R,R+Rsz)      (range Rsz)
			// The union of which covers completely the subsection of the list
			//   [L,R+Rsz)      (range of up to 2*sz)
			// which is the part of the list which we are sorting at the moment.
			//
			// After this Lsz == Rsz and our partitions are of equal size, unless !R
			// in which case the partitions may be unequal.
			for R != nil && Lsz < sz {
				Lsz++
				R = R.Next()
			}

			//   MERGE
			// So, as long as either the L-list is non-empty (Lsz > 0)
			// or the R-list is non-empty (Rsz > 0 and R points to something
			// non-NULL), we have things to merge in our biparted list subsection.
			//
			for Lsz > 0 || (Rsz > 0 && R != nil) {
				// Choose which list to take the next element from.
				// If either list is empty, we must choose from the other one.
				//
				// In any case, the list taken from is moved up and its size
				// decremented.
				//
				// N identifies the new item to be added to the sorted list.
				//
				if Lsz == 0 {
					// The L-side is empty; choose from R.
					N = R
					R = R.Next()
					Rsz--
				} else if Rsz == 0 || R == nil {
					// The R-side is empty; choose from L.
					N = L
					L = L.Next()
					Lsz--
				} else if f(R, L) {
					// If both lists are non-empty, compare the first element of each and
					// choose the lower one.
					N = R
					R = R.Next()
					Rsz--
				} else {
					// "If the first elements compare equal, choose from the L-side."
					N = L
					L = L.Next()
					Lsz--
				}

				if T != nil {
					// "NEXT(T) = N"
					List.MoveAfter(N, T)
				} else {
					A = N
				}

				// "PREV(N) = T"; this is taken care of by MoveAfter

				// N is now the tail.
				T = N
			}

			// Now A (with tail T) is a completely sorted list of the sublist.
			// We have advanced L until it is where R started out, and we have
			// advanced R until it is pointing at the next pair of length-K lists to
			// merge. So set L to the value of R, and go back to the start of this
			// loop.
//.........这里部分代码省略.........
开发者ID:hlandau,项目名称:degoutils,代码行数:101,代码来源:list.go

示例2: mv

func mv(l *list.List, args []string) {
	switch len(args) {
	case 0:
		fmt.Println("What item do you want to move?")
		os.Exit(1)
	case 1:
		fmt.Println("Too few arguments.")
		os.Exit(1)
	case 2:
		// Check if remaining args are integers
		nums := make([]int, len(args))
		for i, a := range args {
			n, err := strconv.Atoi(a)
			if err != nil {
				fmt.Printf("%q is not an item number.\n", a)
				os.Exit(1)
			}
			nums[i] = n
		}

		// Make sure integers is not out of bounds
		if max(nums...) > l.Len() {
			fmt.Printf("item [%d] is out of bounds.\n", max(nums...))
			os.Exit(1)
		} else if min(nums...) < 1 {
			fmt.Printf("item [%d] is out of bounds.\n", min(nums...))
			os.Exit(1)
		} else if nums[0] == nums[1] { // Make sure numbers are different
			fmt.Println("Item alread in place.")
			os.Exit(1)
		}

		// Collect elements
		elements := make([]*list.Element, len(nums))
		itemNumber, element := 1, l.Front()
		for itemNumber <= max(nums...) {
			if itemNumber == nums[0] {
				elements[0] = element
			}
			if itemNumber == nums[1] {
				elements[1] = element
			}
			element = element.Next()
			itemNumber++
		}

		// Update date
		elements[0].Value.(ListItem)[DATE] = time.Now().Format(DATE_FORMAT)

		// Move item
		if nums[0] < nums[1] { // Use moveAfter
			l.MoveAfter(elements[0], elements[1])
		} else { // Use moveBefore
			l.MoveBefore(elements[0], elements[1])
		}
		fmt.Printf("Moving item:[%d] to location:[%d]\n", nums[0], nums[1])

	default:
		fmt.Println("Too many arguments.")
		os.Exit(1)
	}
}
开发者ID:tgrijalva,项目名称:lst,代码行数:62,代码来源:lst.go


注:本文中的container/list.List.MoveAfter方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。