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

每日算法——快乐数、两数之和

202. 快乐数

class Solution {
public:bool isHappy(int n) {unordered_set<int> result_set;while(true){int sum = 0;while(n>0){sum+= (n%10)*(n%10);n/=10;}if(sum==1){return true;}else{if(result_set.find(sum) != result_set.end()){return false;}result_set.insert(sum);}n=sum;}}
};

由于题目中明确了只有循环和==1两种情况,使用快慢指针法同样可以求解:

class Solution {
public:int bitSquareSum(int n) {int sum = 0;while(n > 0){int bit = n % 10;sum += bit * bit;n = n / 10;}return sum;}bool isHappy(int n) {int slow = n, fast = n;do{slow = bitSquareSum(slow);fast = bitSquareSum(fast);fast = bitSquareSum(fast);}while(slow != fast);return slow == 1;}
};

两数之和

时间复杂度为o(n)的解法:使用hash map(存储键值对);

可以利用的细节:

由于是两数之和,根据当前遍历到的值,去map中找是否有target- nums[i]的值即可

class Solution {
public:vector<int> twoSum(vector<int>& nums, int target) {std::unordered_map<int,int> set;for(int i = 0;i<nums.size();i++){auto iter = set.find(target -nums[i]);if(iter != set.end()){return {iter->second,i};}set.insert(pair<int,int>(nums[i],i));}return {};}
};
http://www.xdnf.cn/news/1731.html

相关文章:

  • 域控重命名导致无法登录
  • 回溯--一种暴力搜索算法
  • write函数
  • RTSP播放器实现回调RGB|YUV给视觉算法,然后二次编码推送到RTMP服务
  • ORACLE DATAGUARD遇到GAP增量恢复方式修复RAC环境备机的实践
  • C语言教程(十五):C 语言函数指针与回调函数详解
  • 【高并发】 MySQL锁优化策略
  • rsync实现内网两台服务器文件同步
  • Winddows11官网下载安装VMware Workstation Pro17(图文详解)
  • Linux命令-perf
  • 企业办公即时通讯软件BeeWorks,私有化安全防泄密
  • 【MobaXterm】---修改 MobaXterm 终端 默认字体和大小 保真
  • 基于 C++ 的用户认证系统开发:从注册登录到Redis 缓存优化
  • 【技术派后端篇】整合WebSocket长连接实现消息实时推送
  • 《Python3网络爬虫开发实战(第二版)》配套案例 spa6
  • 数据结构——栈与队列
  • GPU热设计功耗(TDP)与计算效率的平衡艺术:动态频率调节对算法收敛速度的影响量化分析
  • 【Leetcode 每日一题】2799. 统计完全子数组的数目
  • Spring Security结构总览
  • 网络变更:APIC 节点替换
  • 使用Tauri 2.3.1+Leptos 0.7.8开发桌面小程序汇总
  • 【多智能体系统组织方式解析】五大架构赋能智能协作
  • java操作打印机直接打印及详细linux部署(只适用于机器和打印机处于同一个网段中)
  • windbg-A complete guide for Advanced Windows Debugging part1
  • 深入解析 Docker 容器进程的 cgroup 和命名空间信息
  • 机器学习 Day14 XGboost(极端梯度提升树)算法
  • window10部署MinerU
  • 电竞俱乐部护航点单小程序,和平地铁俱乐部点单系统,三角洲护航小程序,暗区突围俱乐部小程序
  • 玩转 C++ 算术运算符(五十二)
  • 拼团退款中采用分片处理降低对数据库