面试题3:两数之和

题目:

设计一个类,包含如下两个成员函数:

    Save(int input)    插入一个整数到一个整数集合里,整数集中可以存在相同值。

    Test(int target)    检验是否存在两个数和为输入值。如果存在这两个数,则返回true,否则返回false。


书中给出的解析:这题相比上一题,只要把<值,下标>改成<值,个数>,第一次遍历将数组存到哈希表里面;第二次遍历数组,判断这个和减去当前数组的值的差值,如果差值在哈希表中存在,满足下面两个条件之一则返回true,(1)当前值不等于差值(2)当前值等于差值,但是在哈希表中该键值对应的值大于等于2。

代码实现:

type TwoSum struct {
	hm []int
}

func (ts *TwoSum) Save(input int) {
	ts.hm = append(ts.hm, input)
}

func (ts *TwoSum) Test(target int) bool {
	m, length := make(map[int]int), len(ts.hm)

	for i := 0;i < length;i += 1 {
		m[ts.hm[i]] += 1
	}
	for i := 0;i < length;i += 1 {
		v := m[target-ts.hm[i]]
		if (2 * ts.hm[i] != target && v != 0) || (2 * ts.hm[i] == target && v > 1) {
			fmt.Println(ts.hm[i], target - ts.hm[i])
			return true
		}
	}
	return false
}

        

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值