IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> leetCode算法发现地址变了导致的坑(242. 有效的字母异位词) -> 正文阅读

[数据结构与算法]leetCode算法发现地址变了导致的坑(242. 有效的字母异位词)

一、概述

最近做这个算法题,发现了一个坑:
https://leetcode.cn/problems/valid-anagram/

给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词。

注意:若 s 和 t 中每个字符出现的次数都相同,则称 s 和 t 互为字母异位词。

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/valid-anagram
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

37个测试用例,过了36个,有一个没有过。

在这里插入图片描述

下面是本人的答案代码:

class Solution {
     public boolean isAnagram(String s, String t) {



        Map<Character,Integer> maps = new HashMap<Character,Integer>();
        Map<Character,Integer> mapt = new HashMap<Character,Integer>();

        for(int i=0;i<s.length();i++){
            char cs = s.charAt(i);
            if(maps.get(cs)!=null){
                int count = maps.get(cs);
                count++;
                maps.put(cs,count);
            }else{
                maps.put(cs,1);
            }
        }

        for(int i=0;i<t.length();i++){
            char cs = t.charAt(i);
            if(mapt.get(cs)!=null){
                int count = mapt.get(cs);
                count++;
                mapt.put(cs,count);
            }else{
                mapt.put(cs,1);
            }
        }


        Set<Character> sSet = maps.keySet();
        Set<Character> tSet = mapt.keySet();
        if(sSet.size()!=tSet.size()){
            return false;
        }else{
            for(Character ff : sSet){
                /*正确解法
                int a = maps.getOrDefault(ff,0);
                int b = mapt.getOrDefault(ff,0);
                if(a!=b){
                    return false;
                }
                */
                //有问题的解法
                if(maps.get(ff)!=mapt.get(ff)){
                    return false;
                }
            }
        }

        return true;
    }
}

感觉比较神奇,也不是判空或者0导致的没有通过之类的。

二、分析

本地调试了一番,问题在这里(简化后):

    public static void main(String[] args) {

        HashMap<Character, Integer> map1 = new HashMap<Character, Integer>();
        HashMap<Character, Integer> map2 = new HashMap<Character, Integer>();

        map1.put('a',127);
        map2.put('a',127);

        map1.put('b',128);
        map2.put('b',128);

        Integer a1 = map1.get('a');
        Integer a2 = map2.get('a');

        Integer b1 = map1.get('b');
        Integer b2 = map2.get('b');

        System.out.println(a1==a2);
        System.out.println(b1==b2);

    }

这段代码比较简单,看起来控制台应该打印2个true的;结果打印了一个true,一个false。
在这里插入图片描述

多次尝试后发现,map里放的数字,如果大于127,那么Integer的地址就会变化,导致了不相等。(原因未知)
在这里插入图片描述
如图,
保存’a’的地址,2个map中都是540,没有问题;
保存127的地址,2个map中都是533,没有问题;
保存’b’的地址,2个map中都是541,没有问题;
但是,保存128的地址,2个map中一个是534,一个是535,出现了问题。

三、结论

声明map时,泛型传入的Integer(只能是Integer,不能是int,会报错),不能直接比较
如果直接比较,比较的是地址,而不是int值;
如果int值大于127,那么Integer的地址就会不同,比较后就会得到不相等的错误结果。

从map中取出Integer后,可以转为int,然后再比较就可以了。

四、备注

IntegerCache类中使用cache[]数组缓存了从-128~127共256个Integer对象,所以数字在这个范围时,地址是一样的;如果不在这个范围,就会new一个新Integer对象并返回。

(意思是,如果Integer a =128的话,就会新创建一个对象;Integer b =128,也会新创建一个对象;a对象与b对象的地址就会不相同)

相关链接:https://blog.csdn.net/MSSPLANET/article/details/122530816

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-10-17 12:59:49  更:2022-10-17 13:04:08 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/25 19:40:16-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码