只出现一次的数字(Java 用Set实现)

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

示例 1:

输入: [2,2,1]
输出: 1

示例 2:

输入: [4,1,2,1,2]
输出: 4

第一种方法:用Set实现

class Solution {
    public int singleNumber(int[] nums) {
        Set<Integer> s=new HashSet<>();
        for(int i=0;i<nums.length;++i){
        	//add:如果指定的元素不存在,则将其指定的元素添加
        	//如果要添加的元素存在,则返回false
        	//所以当重复的数字要add时,if成立,则删除这个重复的数字
            if(!s.add(nums[i])){
                s.remove(nums[i]);
            }
        }
        //此时s里只剩下一个不重复的数字了
        Object[] o=s.toArray();
        //返回0号下标的元素,即返回不重复的数字
        return (int)o[0];
    }
}

第二种方法:异或

class Solution {
    public int singleNumber(int[] nums) {
        int ret=0;
        for(int i=0;i<nums.length;++i){
            ret^=nums[i];
        }
        return ret;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个基于Java的只出现一次数字可视化系统实现: ```java import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import javax.swing.JFrame; import javax.swing.JPanel; public class UniqueNumUI extends JPanel { private int[] nums; public UniqueNumUI(int[] nums) { this.nums = nums; JFrame frame = new JFrame("只出现一次数字可视化系统"); frame.setSize(400, 400); frame.add(this); frame.setVisible(true); } public void paint(Graphics g) { super.paint(g); int x = 50, y = 50, width = 30, height = 30; for (int num : nums) { g.setColor(Color.BLUE); g.setFont(new Font("Arial", Font.BOLD, 16)); g.drawString(String.valueOf(num), x, y); x += width + 10; } int uniqueNum = find(); g.setColor(Color.RED); g.setFont(new Font("Arial", Font.BOLD, 20)); g.drawString("只出现一次数字为:" + uniqueNum, 50, 100); } public int find() { int res = 0; for (int num : nums) { res ^= num; } return res; } } ``` 成员函数说明: - `UniqueNumUI(int[] nums)`:构造函数,输入参数 `nums` 为一个整数数组,表示待查找的数字序列,同时创建一个 `JFrame` 窗口,并将当前类的对象添加到该窗口中。 - `paint(Graphics g)`:绘制函数,用于在当前窗口中绘制数字和结果,其中 `g` 表示绘图对象。 - `find()`:查找函数,返回只出现一次数字。 以下是核心成员函数 `find()` 的流程图: ![只出现一次数字流程图](https://img-blog.csdnimg.cn/20211019165403589.png) 以下是核心成员函数 `find()` 的伪代码: ``` 1. 初始化 res 为 0 2. 遍历 nums 中的每个数字 num 3. 对 res 和 num 进行异或操作 4. 返回 res ``` 核心成员函数 `find()` 的运行原理是,利用异或的性质,相同的数字异或后结果为 0,不同的数字异或后结果为非 0。所以我们只需要将所有数字进行异或操作,最终得到的结果就是只出现一次数字。在可视化系统中,我们将数字和结果绘制在窗口中,使用户能够直观地看到结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值