力扣算法——第16题——go语言

package main

import (
	"fmt"
	"math"
	"sort"
)

func main() {
	var slice1 = make([]int, 0, 5)
	fmt.Println("please input an array: ")
	for i := 1; true; i++ {
		var inputNum int
		fmt.Printf("No.%d : ", i)
		_, err := fmt.Scanf("%d", &inputNum)
		if nil == err {
			slice1 = append(slice1, inputNum)
		}  else {
			break
		}
	}
	printSlice(slice1)

	var target int
	fmt.Println("please input the target: ")
	fmt.Scanf("%d", &target)

	fmt.Println(threeSumClosed(slice1, target))

}

func printSlice(x []int){
	fmt.Printf("slice=%v len=%d cap=%d \n",x,len(x),cap(x))
}

func threeSumClosed(nums []int, target int) int {
	sort.Ints(nums)
	totalLenth := len(nums)
	best := math.MaxInt32

	update := func(cur int) {
		if abs(cur - target) < abs(best - target) {
			best = cur
		}
	}

	for left := 0; left < totalLenth - 1; left++ {
		if (left > 0) && (nums[left] == nums[left + 1]) {
			continue
		}

		mid, right := left + 1, totalLenth - 1
		for mid < right {
			sum := nums[left] + nums[mid] + nums[right]
			if sum == target {
				return target
			}

			update(sum)

			if sum > target {
				right0 := right - 1
				if (mid < right0) && (nums[right0] == nums[right]) {
					right0--
				}
				right = right0
			} else {
				mid0 := mid + 1
				if (mid0 < right) && (nums[mid0] == nums[mid]) {
					mid0++
				}
				mid = mid0
			}
		}
	}
	return best
}

func abs(a int) int {
	if(a < 0) {
		return -1*a
	}
	return a
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一个旅者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值