当前位置: 首页 > article >正文

算法通关村第十三关|白银|数字与数学高频问题

1.实现加法专题

1.1 数组实现整数加法

public int[] plusOne(int[] digits) {
	int len = digits.length;
    for (int i = len - 1; i >= 0; i--) {
        digits[i]++;
        digits[i] %= 10;
        if (digits[i] != 0) {
            return digits;
        }
    }
    digits = new int[len + 1];
    digits[0] = 1;
    return digits;
}

1.2 字符串加法

public String addStrings(String num1, String num2) {
    // add 是进位
	int i = num1.length() - 1, j = num2.length() - 1, add = 0;
    StringBuffer ans = new StringBuffer();
    while (i >= 0 || j >= 0 || add != 0) {
        int x = i >= 0 ? num1.charAt(i) - '0' : 0;
        int y = j >= 0 ? num2.charAt(j) - '0' : 0;
        int result = x + y + add;
        ans.append(result % 10);
        add = result / 10;
        i--;
        j--;
    }
    ans.reverse();
    return ans.toString();
}

1.3 二进制加法

public String addBinary(String a, String b) {
	StringBuilder ans = new StringBuilder();
    int ca = 0;
    for (int i = a.length() - 1, j = b.length() - 1; i > 0 || j > 0; i--, j--) {
        int sum = ca;
        sum += i >= 0 ? a.charAt(i) - '0' : 0;
        sum += j >= 0 ? b.charAt(j) - '0' : 0;
        ans.append(sum % 2);
        ca = sum / 2;
    }
    // 这种写法在循环中没有解决最后一个进位的问题
    ans.append(ca == 1 ? ca : "");
    return ans.reverse().toString();
}

2.幂运算

2.1 求2的幂

public boolean isPowerOfTwo(int n) {
	if (n <= 0) {
        return false;
	}
	while (n % 2 == 0) {
        n / 2;
    }
	return n == 1;
}

2.2 求2的幂但是采用位运算

public boolean isPowerOfTwo(int n) {
	return n > 0 && (n & (n - 1)) == 0;
}

2.3 求3的幂

除本方法外,还可以用整形范围内最大的3的幂来除以输入的n,仅需要一次除法,如果余数为0即为3的幂。

public boolean isPowerOfThree(int n) {
	if (n < 0) {
    	return false;
	}
	while (n % 3 == 0) {
        n /= 3;
    }
	return n == 1;
}

3.指数运算

原题:力扣50.

class Solution {
    public double myPow(double x, int n) {
        long N = n;
        return N >= 0 ? quickMul(x, N) : 1.0 / quickMul(x, -N);
    }
    public double quickMul(double x, long N) {
        double ans = 1.0;
        double x_contribute = x;
        while (N > 0) {
        	// N的二进制位为1时ans才需要乘该位的对应次方的数
            if (N % 2 == 1) {
                ans *= x_contribute;
            }
            x_contribute *= x_contribute;
            N /= 2;
        }
        return ans;
    }
}

如果对您有帮助,请点赞关注支持我,谢谢!❤
如有错误或者不足之处,敬请指正!❤
个人主页:星不易 ❤
算法通关村专栏:不易|算法通关村 ❤


http://www.kler.cn/a/158773.html

相关文章:

  • 游戏引擎学习第16天
  • springboot上传下载文件
  • 面试题:Kafka(一)
  • Linux :进程间通信之管道
  • SpringBoot实现WebSocket
  • 现代密码学|公钥密码体制 | RSA加密算法及其数学基础
  • 项目文章|冰川宏病毒功能多样性新进展
  • re:Invent 云端历程:我与 2023 亚马逊云科技 re:Invent 大会
  • 万应低代码:智能化引领新工业时代
  • C++初阶-string的使用
  • 试着总结一下:pg的vacuum机制
  • 数据结构:链表应用:第8关:链表的逆转
  • ES6中 对象合并
  • 2021年GopherChina大会-核心PPT资料下载
  • 关于回收套接字和释放上下文的顺序
  • Spring Boot 3.2.0 Tomcat虚拟线程初体验 (部分装配解析)
  • elasticsearch副本和分片
  • 【实战技能】 单步运行源码分析,一期视频整明白FreeRTOS内核源码框架和运行机制,RTOS Trace链表功能展示
  • 深入学习Synchronized各种使用方法
  • springboot 整合 Spring Security 上篇
  • 在外包待了6年,技术退步太明显......
  • 【数据结构实验】树(一)构建二叉查找树(BST)
  • 了解 ignore_above 参数对 Elasticsearch 中磁盘使用的影响
  • Linux: FS: inotify
  • C语言还会存在多久
  • 数据结构基础(不带头节点的单向非循环链表)