强健寒风

文章
6
资源
0
加入时间
3年0月8天

给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。说明:你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗?

输入: [2,2,1]输出: 1class Solution { public int singleNumber(int[] nums) { int ans = 0; for(int num: nums) { ans ^= num; } return ans; }}解题思路● 题目中说明其余元素都出现 2 次,只有某一个元素只出现了1次● 由于异或在位运算时相同为0,不同为1,因此所有...

9.2链表(五)——给定两个用链表表示的整数,每个结点包含一个数位。这些数位是反向存放的,也就是个位排在链表首部

/** * 功能:给定两个用链表表示的整数,每个结点包含一个数位。这些数位是反向存放的,也就是个位排在链表首部。 * 编写函数对这两个整数求和,并用链表形式返回结果。 * 进阶:假设这些数位是正向存放的,请再做一遍。 */题目一:反向存放 //将两个节点的值逐一相加,如有进位,则转入下一个节点 public static LinkedListN