【优选算法】(第十八篇)

目录

两整数之和(medium)

题目解析

讲解算法原理

编写代码

只出现⼀次的数字II(medium)

题目解析

讲解算法原理

编写代码


两整数之和(medium)

题目解析

1.题目链接:. - 力扣(LeetCode)

2.题目描述

给你两个整数a和b,不使⽤运算符+和-,计算并返回两整数之和。

⽰例1:

输⼊:a=1,b=2

输出:3

⽰例2:

输⼊:a=2,b=3

输出:5

提⽰:

-1000<=a,b<=1000

讲解算法原理

解法(位运算):

算法思路:

◦ 异或 ^ 运算本质是「⽆进位加法」;

◦ 按位与 & 操作能够得到「进位」;

◦ 然后⼀直循环进⾏,直到「进位」变成 0 为⽌。

编写代码

c++算法代码:

复制代码
class Solution
{
public:
 int getSum(int a, int b) 
 {
 while(b != 0)
 {
 int x = a ^ b; // 先算出⽆进位相加的结果
 unsigned int carry = (unsigned int)(a & b) << 1; // 算出进位 a = x;
 b = carry;
 }
 return a;
 }
};

java算法代码:

复制代码
class Solution {
 public int getSum(int a, int b) {
 while(b != 0)
 {
 int x = a ^ b; // 先算出⽆进位相加的结果 int carry = (a & b) << 1; // 计算进位 a = x;
 b = carry;
 }
 return a;
 }
}

只出现⼀次的数字II(medium)

题目解析

1.题目链接:. - 力扣(LeetCode)

2.题目描述

给你⼀个整数数组nums,除某个元素仅出现⼀次外,其余每个元素都恰出现三次。请你找出并返回那个只出现了⼀次的元素。

你必须设计并实现线性时间复杂度的算法且不使⽤额外空间来解决此问题。

⽰例1:

输⼊:nums=[2,2,3,2]

输出:3

⽰例2:

输⼊:nums=[0,1,0,1,0,1,99]

输出:99

提⽰:

1<=nums.length<=3*104

-231<=nums[i]<=231-1

nums中,除某个元素仅出现⼀次外,其余每个元素都恰出现三次

讲解算法原理

解法(⽐特位计数):

算法思路:

设要找的数位 ret 。

由于整个数组中,需要找的元素只出现了「⼀次」,其余的数都出现的「三次」,因此我们可以根据所有数的「某⼀个⽐特位」的总和 %3 的结果,快速定位到 ret 的「⼀个⽐特位上」的值是0 还是 1 。

这样,我们通过 ret 的每⼀个⽐特位上的值,就可以将 ret 给还原出来。

编写代码

c++算法代码:

class Solution

{

public:

int singleNumber(vector<int>& nums)

{

int ret = 0;

for(int i = 0; i < 32; i++) // 依次去修改 ret 中的每⼀位 {

int sum = 0;

for(int x : nums) // 计算nums中所有的数的第 i 位的和 if(((x >> i) & 1) == 1)

sum++;

sum %= 3;

if(sum == 1) ret |= 1 << i;

}

return ret;

}

};

java算法代码:

复制代码
class Solution
{
 public int singleNumber(int[] nums) 
 {
 int ret = 0;
 for(int i = 0; i < 32; i++) // 依次修改 ret 中的每⼀个⽐特位 {
 int sum = 0;
 for(int x : nums) // 统计 nums 中所有的数的第 i 位的和 if(((x >> i) & 1) == 1)
 sum++;
 sum %= 3;
 if(sum == 1) ret |= 1 << i;
 }
 return ret;
 }
}
相关推荐
二哈赛车手4 小时前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring
吃好睡好便好4 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
栗子~~5 小时前
JAVA - 二层缓存设计(本地缓冲+redis缓冲+广播所有本地缓冲失效) demo
java·redis·缓存
YDS8295 小时前
DeepSeek RAG&MCP + Agent智能体项目 —— RAG知识库的搭建和接口实现
java·ai·springboot·agent·rag·deepseek
仰泳之鹅5 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
未若君雅裁6 小时前
MyBatis 一级缓存、二级缓存与清理机制
java·缓存·mybatis
于小猿Sup6 小时前
VMware在Ubuntu22.04驱动Livox Mid360s
linux·c++·嵌入式硬件·自动驾驶
AI人工智能+电脑小能手6 小时前
【大白话说Java面试题 第65题】【JVM篇】第25题:谈谈对 OOM 的认识
java·开发语言·jvm
阿维的博客日记7 小时前
Nacos 为什么能让配置动态生效?(涉及 @RefreshScope 注解)
java·spring
雨辰AI7 小时前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战
java·数据库·mysql·政务