算法题总结(十五)

这篇博客总结了算法题目,包括迭代问题中的数字序列查找,利用二进制操作解决计算次幂和数组中数字出现次数的问题,以及贪心算法在分糖果和主持人调度等场景的应用。
摘要由CSDN通过智能技术生成

按照方法分类

(五)迭代问题

1、 数字以0123456789101112131415…的格式序列化到一个字符序列中。在这个序列中,第5位(从下标0开始计数)是5,第13位是1,第19位是4,等等。请写一个函数,求任 意第n位对应的数字。

  • 迭代+求整/求余(找规律)

(六)转为数字的二进制问题

1、计算 x 的 n 次幂函数

  • 用到与操作(&1)判断奇偶、移位>>删除二进制的最右一位

2、 数组中数字出现次数(在一个数组 nums 中除两个数字只出现一次之外,其他数字都出现了两次。请找出那个只出现一次的数字)

  • 异或运算^(相同数字异或为0)+左移+与操作。
  • 构造一个变量m,通过左移m以及m&num,将num分成两个子数组(m&num=0,m&num=1);
  • 每个子数组分别异或,取得两个只出现一次的数
    >> :右移 最高位是0,左边补齐0;最高为是1,左边补齐1
    << :左移 左边最高位丢弃,右边补齐0
    >>>:无符号右移 无论最高位是0还是1࿰
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值