news 2026/5/31 2:07:12

华为OD机考双机位C卷- 不含101的数(Java Python JS C/C++ GO )

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
华为OD机考双机位C卷- 不含101的数(Java Python JS C/C++ GO )

最新华为上机考试

真题目录:点击查看目录
华为OD面试真题精选:点击立即查看
华为OD机考双机位C卷- 不含101的数

题目描述

小明在学习二进制时,发现了一类不含 101的数,也就是:

将数字用二进制表示,不能出现 101 。
现在给定一个整数区间 [l,r] ,请问这个区间包含了多少个不含 101 的数?

输入描述

输入的唯一一行包含两个正整数 l, r( 1 ≤ l ≤ r ≤ 10^9)。

输出描述

输出的唯一一行包含一个整数,表示在 [l,r] 区间内一共有几个不含 101 的数。

示例1

输入

1 10

输出

8

说明

区间 [1,10] 内, 5 的二进制表示为 101 ,10的二进制表示为 1010 ,因此区间 [ 1 , 10 ] 内有 10−2=8 个不含 101的数。

示例2

输入

10 20

输出

7

说明

区间 [10,20] 内,满足条件的数字有 [12,14,15,16,17,18,19] 因此答案为 7。

解题思路

本题乍看是很简单的题目,直接进制转换,暴力法不就得了。但是你注意看范围是【1 ≤ l ≤ r ≤ 10^9】,暴力肯定会超时。这题使用的是数位DP

数位dp总结 之 从入门到模板_wust_wenhao的博客-CSDN博客

具体思路是从高位到低位逐位枚举,对于每一位,枚举它的取值,并根据前一位和前两位的值来判断是否符合条件。同时,使用记忆化数组来避免重复计算。

具体实现中,可以将数字转换为二进制数,然后递归处理每一位。递归函数中,p表示当前处理到的二进制位,limit表示当前位是否受到上限制,f表示记忆化数组,arr表示二进制数,pre表示前一位的值,prepre表示前两位的值。递归结束条件是处理完所有二进制位,此时返回1。在递归过程中,统计符合条件的数的个数,并使用记忆化数组避免重复计算。

Java

importjava.util.
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/28 22:21:35

JNPF 全局设置实操,教你 3 步定位 + 解锁核心功能

常用功能找半天、多身份权限切换繁琐、多组织切换不便? JNPF 全局设置功能一站式解决 —— 支持菜单搜索、收藏快捷跳转,多身份切换即时读取对应权限,多组织切换可设默认组织适配逐级审批。本文拆解JNPF全局设置核心操作,帮你提升…

作者头像 李华
网站建设 2026/5/29 0:10:13

《动态场景下全局光照探针实时更新优化指南》

动态场景中全局光照的实时落地,核心矛盾始终聚焦于光影关系的动态流变与传统光照探针静态采样之间的底层错配,这种错配并非简单的技术参数失衡,而是探针与场景动态元素之间缺乏有效的交互感知逻辑,最终直接导致光照表现与物理现实的脱节。当开放世界、动态交互类场景成为主…

作者头像 李华
网站建设 2026/5/30 2:19:40

曜华硬核出征!三台核心光伏检测设备启运,力擎行业品质标杆

1月26日,武汉曜华激光科技有限公司自主研发生产的两台太阳能组件IV测试仪及一台太阳能小组件EL缺陷检测仪顺利完成调试、检验,正式发运交付。此次发运的设备涵盖光伏组件电性能测试与内部缺陷检测两大核心领域,将精准赋能客户生产线质检、实验…

作者头像 李华
网站建设 2026/5/30 0:36:37

现代服务管理指南:Jira Service Management + Rovo的AI自动化架构与实战应用

服务管理面临的挑战 随着社会的进步及数字企业的兴起,全天候运作的服务和支援成为必然趋势,数字经济的蓬勃发展也使得远程协作模式逐渐成熟。这就要求支持服务时刻在线,满足客户随时可能产生的服务需求,而分散在各地的支持团队成…

作者头像 李华