二进制算法题+回文链表

这篇具有很好参考价值的文章主要介绍了二进制算法题+回文链表。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。


一、剑指 Offer II 002. 二进制加法

  1. 先计算两个字符串公共的部分,需要维护三个变量:两个数组的指针idx+一个进位变量up
  2. 注意,这里用StringBuffer来存储结果,先存储的是个位,所以最后需要reverse一下。
    public String addBinary(String a, String b) {
        char[] ca = a.toCharArray();
        char[] cb = b.toCharArray();
        // for(int i=ca.length-1;i>=0;i--){
        //     int sum = ca[i]+cb[i];
        //     if(sum>1){

        //     }
        // }

        int idxa = ca.length-1;
        int idxb = cb.length-1;
        int up=0;
        StringBuffer sb = new StringBuffer();//用来记录最终结果
        while(idxa>=0&&idxb>=0){//先计算公共的部分
            int val = (ca[idxa]-'0')+(cb[idxb]-'0')+up;
            sb.append(val%2);
            up=val/2;
            idxa--;
            idxb--;
        }
        while(idxa>=0){
            int val = (ca[idxa]-'0')+up;
            sb.append(val%2);
            up=val/2;
            idxa--;
        }
        while(idxb>=0){
            int val = (cb[idxb]-'0')+up;
            sb.append(val%2);
            up=val/2;
            idxb--;
        }
        if(up==1){
            sb.append("1");
        }
        return sb.reverse().toString();

    }

21分钟

二、693. 交替位二进制数

  1. 如何看一个字符是否在变化?维护一个temp变量来记录他上一次的结果。
  2. 模拟十进制转二进制:先对2求余得到低位,再除以2得到下一个数。
    public boolean hasAlternatingBits(int n) {
        int temp=-1;
        while(n>0){
            int wei = n%2;
            if(wei==temp){
                return false;
            }
            temp=wei;
            n=n/2;
        }
        return true;
    }

10分钟

三、剑指 Offer 15. 二进制中1的个数

  • 自己看到题目的第一想法

  • 看完题解之后的想法

  • 自己实现过程中遇到的问题总结

    public int hammingWeight(int n) {
        // String s = String.valueOf(n);
        String s = Integer.toBinaryString(n);
        int num=0;
        for(int i=0;i<s.length();i++){
            if(s.charAt(i)=='1'){
                num++;
            }
        }
        return num;
    }

29分钟文章来源地址https://www.toymoban.com/news/detail-465347.html

四、剑指 Offer II 027. 回文链表

  1. 链表无法双指针遍历,所以先反转后半段链表(这里需要先知道中心点)。
  2. 有几个地方需要注意:1.如果是奇数节点,需要中心点向后移动一位。2.判断回文的终止条件是右指针为空。
    public boolean isPalindrome(ListNode head) {
        ListNode slow = head;
        ListNode fast = head;
        while(fast!=null&&fast.next!=null){
            slow=slow.next;
            fast=fast.next.next;
        }//先找到中心点
        // if(fast!=null){
        //     fast=fast.next;
        // }
        if(fast!=null){
            slow=slow.next;
        }
        ListNode right = reverse(slow);
        ListNode left=head;
        // while(left!=null&&right!=null){
        while(right!=null){
            if(left.val!=right.val){
                return false;
            }
            left=left.next;
            right=right.next;
        }
        return true;

    }
    public ListNode reverse(ListNode head){
        ListNode pre = null;
        ListNode cur = head;
        while(cur!=null){
            ListNode next = cur.next;
            cur.next=pre;
            pre = cur;
            cur=next;
        }
        return pre;

    }

总结

到了这里,关于二进制算法题+回文链表的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 力扣67. 二进制求和算法

    这道题需要,给你两个字符串比如 答案是:\\\"10101\\\" 然后需要你给出计算结果,那么我们很容易想到两种做法 1. 调库做法:直接转化为整数,然后用内置函数做进制转换直接计算出结果 2. 计算做法:将十进制思维移植过来,对每一位加并且做carry操作,最后得出结果 笔者最初

    2024年01月16日
    浏览(41)
  • 【算法题】67. 二进制求和

    给你两个二进制字符串 a 和 b ,以二进制字符串的形式返回它们的和。 示例 1: 输入:a = \\\"11\\\", b = \\\"1\\\" 输出:\\\"100\\\" 示例 2: 输入:a = \\\"1010\\\", b = \\\"1011\\\" 输出:\\\"10101\\\" 提示: 1 = a.length, b.length = 10^4 a 和 b 仅由字符 \\\'0\\\' 或 \\\'1\\\' 组成 字符串如果不是 \\\"0\\\" ,就不含前导零

    2024年01月23日
    浏览(69)
  • 深入解析位运算算法:探索数字的二进制秘密

    位运算是计算机科学中的重要概念,用于在二进制数字层面进行各种操作。本文将深入介绍位运算的基本操作,以及它在判断、计算和处理数字中的应用,包括判断2的幂次方、位图法、位掩码和寻找缺失数字等。 位操作是通过对数字的二进制表示进行操作,实现各种功能。

    2024年02月11日
    浏览(42)
  • 算法leetcode|67. 二进制求和(rust重拳出击)

    给你两个二进制字符串 a 和 b ,以二进制字符串的形式返回它们的和。 1 = a.length, b.length = 10 4 a 和 b 仅由字符 \\\'0\\\' 或 \\\'1\\\' 组成 字符串如果不是 \\\"0\\\" ,就不含前导零 面对这道算法题目,二当家的再次陷入了沉思。 直接用API将字符串按照2进制转成整型,相加,然后再按照2进制转

    2024年02月14日
    浏览(45)
  • C/C++ 高精度(加减乘除)算法二进制优化

    第一章 简单实现 第二章 压位优化 第三章 二进制优化(本章) 上一章《C/C++ 高精度(加减乘除)算法压位优化》实现了优化的高精度计算,采用int32的整型数组每个元素可以储存9个10进制数字,想要再进一步优化计算速度,可以改变数据存储方式,采用二进制存储数字。依然采

    2024年02月11日
    浏览(39)
  • 【算法随记】二进制数的后缀相同不代表它们是倍数关系

    https://codeforces.com/contest/893/problem/B 第三个点是81142,wa了 打出来看是01101111001111001(倒序),我的输出是6(110),感觉没问题呀,正好是最后面的三位 傻了 110xxxxxx不是110的倍数,xxxxxx110也不是 就像7xxx未必是7的倍数,xxxx7也未必是7的倍数 只有xxxxx10是10的倍数,xxxxx1是1的倍数

    2024年02月12日
    浏览(40)
  • 【JavaScript数据结构与算法】字符串类(计算二进制子串)

    个人简介 👀 个人主页: 前端杂货铺 🙋‍♂️ 学习方向: 主攻前端方向,也会涉及到服务端(Node.js) 📃 个人状态: 在校大学生一枚,已拿多个前端 offer(秋招) 🚀 未来打算: 为中国的工业软件事业效力 n 年 🥇 推荐学习:🍍前端面试宝典 🍉Vue2 🍋Vue3 🍓Vue2/3项目

    2024年02月05日
    浏览(42)
  • 【我们一起60天准备考研算法面试(大全)-第二十九天 29/60】【二进制】

    专注 效率 记忆 预习 笔记 复习 做题 欢迎观看我的博客,如有问题交流,欢迎评论区留言,一定尽快回复!(大家可以去看我的专栏,是所有文章的目录) 文章字体风格: 红色文字表示:重难点★✔ 蓝色文字表示:思路以及想法★✔ 如果大家觉得有帮助的话,感谢大家帮

    2024年02月15日
    浏览(49)
  • 剑指 offer 链表算法题:链表倒数第k个节点

    题目描述: 输入一个链表,输出该链表中倒数第k个节点。为了符合大多数人的习惯,本题从1开始计数,即链表的尾节点是倒数第1个节点。         例如,一个链表有 6 个节点,从头节点开始,它们的值依次是 1、2、3、4、5、6。这个链表的倒数第 3 个节点是值为 4 的节点

    2024年02月13日
    浏览(34)
  • 【算法】Reconstruct a 2-Row Binary Matrix 重构 2 行二进制矩阵

    给你一个 2 行 n 列的二进制数组: 矩阵是一个二进制矩阵,这意味着矩阵中的每个元素不是 0 就是 1。 第 0 行的元素之和为 upper。 第 1 行的元素之和为 lower。 第 i 列(从 0 开始编号)的元素之和为 colsum[i],colsum 是一个长度为 n 的整数数组。 你需要利用 upper,lower 和 colsu

    2024年02月12日
    浏览(51)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包