[贪心+数学/数学+位运算] 两种方法O(1)解决 消减整数

 标题:[贪心+数学/数学+位运算] 两种方法O(1)解决 消减整数 

个人主页@水墨不写bug

目录

 一、题目:消减整数(Newcoder)

 二、题目分析

1.理解题意:

 2.解决问题

解法详解一:贪心+数学

解法一参考代码:

解法详解二:数学+位运算

解法二参考代码:


 正文开始:

前言:

        本文是我在刷题的时候偶然遇到的算法题,对此题我有自己想出来的做法,可以达到O(1)时间复杂度,与常用的解法相比 方法比较巧妙,于是分享出来供参考学习,如果有错误,也欢迎不吝赐教。

 一、题目:消减整数(Newcoder)

题号:NC219038
时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 262144K,其他语言524288K
64bit IO Format: %lld


题目描述

        给出一个正整数H,从1开始减,第一次必须减1,每次减的数字都必须和上一次相同或者是上一次的两倍,请问最少需要几次能把H恰好减到0。


输入描述:

        第一行给出一个正整数T,  T >= 1 并且 T <= 10^4

        接下来T行每行一个整数H,  满足  1≤H≤10^9


输出描述:

每行一个正整数代表最少的次数

示例1

输入

3(T)
接下来T行输入测试用例
3
5
7

输出

2
3
3

 二、题目分析

1.理解题意:

        为了方便,我们只举一个例子:3

        3第一次-1;得到2

        第二次有两种选择:继续-1 或者 (减1的二倍)-2

        如果选择-2,得到0,则最短路径就是2。

 

 2.解决问题

        在正式讲解可行的算法之前,先考虑暴力解法(因为可行解法往往是暴力解法的优化):

        对于一个数,每次要么-A,要么-2*A;(A是下一次需要减的数)

                于是暴力解法就是对每一次减,都逝一逝(A和2*A)。这里我就不试了,为什么想必大家都知道。 

        复杂度:O(2^N)

解法详解一:贪心+数学

         贪心:每次都减2*A,这样能减的更快,用的次数更少;但是不能保证正确性,比如下面的这个特例:

        这就由于贪心而错失了正确答案。 正确的处理方法是在每次贪心之前,需要进行一步判断。

        我们暂且称上述的贪心为短视的“简单贪心”。假设一个数,经过“简单贪心”刚好可以减到0:

这就意味着这个数一定 是2a的整数倍!!

        那么就只需要在每次减之前,让这个数 % (2*A),如果等于0,这就意味着我们目前可以得正确的结果。意味着我们走在正确的二叉树分支上。意味着我们是在得到正确答案的基础上贪心!


解法一参考代码:

#include <iostream>
using namespace std;int t, h;int fun()
{int ret = 0, a = 1;while(h){h -= a;ret++;if(h % (a * 2) == 0){a *= 2;}}return ret;
}int main()
{cin >> t;while(t--){cin >> h;cout << fun() << endl;}return 0;
}

解法详解二:数学+位运算

         这个解法是我自己想到的解法。起初我想到位运算,因为每次减的数都是2的N次方,

(1,2,4,8,16....),于是我写出了下面的代码,并暗自得意这道题,也就不过如此嘛:

int cut_int(int n)
{int ans = 0;for(int i = 0;i < 32;++i){if(((n >> i) & 1) == 1){ans++;}}return ans;
}
int main()
{int n;cin>>n;int tem;while(n--){cin>>tem;cout<<cut_int(tem)<<endl;}return 0;
}

        但是提交后,我立刻发现了问题所在:2的倍数是一个次数一个次数加上去的,在合理的范围内,每一个2的次方数都至少要出现一次! 

        仅仅统计二进制1位的出现次数得出的是错误的答案!因为减的数字是从1开始的。不可能直接越过4而减去8/16/32.....

        于是, 我们可以先预先算出2出现的最高次数N,再一次减去(2的次方项 1,2,4,8,16....),这样不就保证不会出现上述的越级的行为!!

        对于2的次方项,我们可以通过等比数列前n项求和公式计算:

        然后让目标数字num-(Sn),得到的剩下的数,不就直接可以通过统计二进制位的方式来计算减的次数了嘛!!

总结记目标数A,2出现的最高次项N

        由于减去的数字从1开始,以次乘二,所以减去的数中一定是依次增大的(1,2,4,8.)2的次方项一定会每个都至少出现一次!

        我们通过一次操作:让目标数-(2的次方项1,2,4...直到最高次项N,这个过程等比数列求和计算),同时操作次数+N;从此我们就得到了新的目标数B,B就可以通过计算二进制位上1的个数来得到最终的答案。 


解法二参考代码:

#include <iostream>
#include<cmath>
using namespace std;int cut_int(int n)
{int ans = 0;int fn = 0;for(int i = 1; pow(2,i) - 1 <= n;++i){fn = i;}ans += fn;n -= (pow(2,fn)-1);for(int i = 0;i < 32;++i){if(((n >> i) & 1) == 1){ans++;}}return ans;
}
int main()
{int n;cin>>n;int tem;while(n--){cin>>tem;cout<<cut_int(tem)<<endl;}return 0;
}

完~

未经作者同意禁止转载

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1548710.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

WiFi无线连接管理安卓设备工具:WiFiADB

介绍 WiFi ADB 使您能够通过 WiFi TCP/IP 连接直接在设备上轻松调试和测试 Android 应用&#xff0c;无需使用 USB 数据线。在启用 WiFi 上的 ADB 后&#xff0c;打开控制台将电脑连接到设备。 手机和电脑在同一个WiFi然后电脑上运行adb connect x.x.x.x:x命令即可 下载 谷…

MindSearch 部署到Github Codespace 和 Hugging Face Space

和原有的CPU版本相比区别是把internstudio换成了github codespace。 教程是https://github.com/InternLM/Tutorial/blob/camp3/docs/L2/MindSearch/readme_github.md 复现步骤&#xff1a; 根据教材安装环境和创建硅基流动 API 然后启动前后端 然后按照教材部署到 Huggi…

一站式家装服务管理系统

摘 要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本一站式家装服务管理系统就是在这样的大环境下诞生&#xff0c;其可以帮助管理者在短时间内处理完毕庞大的数…

基于Hive和Hadoop的病例分析系统

本项目是一个基于大数据技术的医疗病历分析系统&#xff0c;旨在为用户提供全面的病历信息和深入的医疗数据分析。系统采用 Hadoop 平台进行大规模数据存储和处理&#xff0c;利用 MapReduce 进行数据分析和处理&#xff0c;通过 Sqoop 实现数据的导入导出&#xff0c;以 Spark…

《征服数据结构》哈夫曼树(Huffman Tree)

摘要&#xff1a; 1&#xff0c;哈夫曼树的介绍 2&#xff0c;哈夫曼树的构造 3&#xff0c;哈夫曼树带权路径长度计算 4&#xff0c;哈夫曼树的编码 5&#xff0c;哈夫曼树的解码 1&#xff0c;哈夫曼树的介绍 哈夫曼树(Huffman Tree)也叫霍夫曼树&#xff0c;或者赫夫曼树&am…

学校周赛(1)

A - Short Sort 题目&#xff1a; 思路&#xff1a; 本条题目只允许改一处地方&#xff0c;只有三个字母&#xff0c;我们可以直接枚举所有移动过的结果&#xff0c;同时使用哈希去记录其值&#xff0c;对于每一个输入我们都寻找是否有这个值记录&#xff0c;有则输出YES否则…

微深节能 环形运动机械定位控制系统 格雷母线

微深节能的环形运动机械定位控制系统中的格雷母线&#xff0c;是一种高精度、无磨损的非接触式位置检测系统&#xff0c;特别适用于环形运动机械的定位控制。该系统主要由格雷母线、天线箱、电气柜等关键部件组成&#xff0c;其核心在于格雷母线这一特殊的编码线。 格雷母线概述…

JAVA一站式台球学习平台多端畅享助教教练系统小程序源码

​一站式台球学习平台 —— 多端畅享助教教练系统 &#x1f31f;【开篇&#xff1a;解锁台球新境界】&#x1f31f; 你是否厌倦了传统台球学习的枯燥与局限&#xff1f;想要随时随地&#xff0c;都能享受专业级的台球指导吗&#xff1f;今天&#xff0c;就让我为你揭秘一款颠覆…

JITWatch安装使用方法

JITWatch 版本1.4.2 JDK 版本 11以上 1.下载JITWatch&#xff1a; https://github.com/AdoptOpenJDK/jitwatch/releases/download/1.4.2/jitwatch-ui-1.4.2-shaded-win.jar 2.启动 bat脚本执行&#xff1a;通过启动jar包方式启动JITWatch echo off start cmd /c "ti…

SpringBoot+Activiti7工作流入门实例

目录 文章目录 目录准备Activiti建模工具1、BPMN-js在线设计器1.1 安装1.2 使用说明1.3运行截图 2、IDEA安装Activiti Designer插件2.1安装插件2.2 设置编码格式防止中文乱码2.3 截图 简单工作流入门实例1. 新建Spring Boot工程2. 引入Activiti相关依赖添加版本属性指定仓库添加…

探索分布式IO模块的介质冗余:赋能工业自动化的稳健之心

在日新月异的工业自动化领域&#xff0c;每一个细微环节的稳定性都直接关系到生产线的效率与安全。随着智能制造的深入发展&#xff0c;分布式IO&#xff08;Input/Output&#xff09;模块作为连接现场设备与控制系统的关键桥梁&#xff0c;其重要性日益凸显。我们自主研发的带…

RAG+llamaindex+DSW实操

本文纯干货,不做任何原理性讲解,适合于有一定基础的伙伴进行实践,本次文章将分为以下几个部分来介绍: 环境搭建LlamaIndex 使用本地知识库准备基本原理: 1. 环境搭建 1.1 配置基础环境 创建虚拟环境,环境名称可以自行取,我的是"llamaindex" conda create -n ll…

「iOS」——KVC

iOS学习 前言KVC模式KVC设值KVC取值KVC使用keyPathKVC处理异常处理不存在的key处理nil异常 KVC处理字典KVC高阶消息传递 总结 前言 对KVC模式的简单学习和总结。 KVC模式 KVC&#xff08;Key-Value Coding&#xff0c;键值编码&#xff09;是一种通过字符串来访问对象属性的机…

双端之Nginx+Php结合PostgreSQL搭建Wordpress

第一台虚拟机:安装 Nginx 更新系统包列表: sudo apt update安装 Nginx及php扩展: sudo apt install nginx php-fpm php-pgsql php-mysqli -y启动 Nginx 服务: sudo systemctl start nginx检查 Nginx 是否正常运行: xdg-open http://localhost注意:终端命令打开网址 …

腾讯云SDK产品功能

本文主要介绍音视频终端 SDK&#xff08;腾讯云视立方&#xff09;的核心功能。 直播推流 音视频终端 SDK&#xff08;腾讯云视立方&#xff09;为终端直播场景提供强大的 RTMP、RTC 推流能力&#xff0c;配合云直播&#xff08;CSS&#xff09;全球布局的2000节点&#xff0…

数据结构及基本算法

目录 第一章 概论 第一节 引言 第二节 基本概念和常用术语 第三节 算法的描述与分析 第二章 线性表 第一节 线性表定义和基本运算个 一、线性表的逻辑定义 二、线性表的基本运算 第二节 线性表的顺序存储和基本运算的实现 一、线性表的顺序存储 二、顺序表上基本运算…

【网络安全】-访问控制-burp(1~6)

文章目录 前言   1.Lab: Unprotected admin functionality  2.Lab: Unprotected admin functionality with unpredictable URL   3.Lab: User role controlled by request parameter   4.Lab:User role can be modified in user profile  5.Lab: User ID controlled by…

山海优选电商平台卷轴模式订单系统核心架构解析

山海优选卷轴模式的订单核心源码是涉及订单处理、支付、搜索、状态管理等关键功能的代码部分。由于直接提供完整的源代码可能涉及版权和隐私保护问题&#xff0c;我将基于参考文章中的信息&#xff0c;概述该模式订单核心源码的主要结构和功能点。 一、订单核心源码概述 在山海…

C语言线程

线程 多个进程中通过轮流使用CPU来完成自己的任务&#xff0c;如果多个进程的操作都一模一样那么CPU的开销就会很大&#xff0c;因为进程的地址都是私有的&#xff0c;如果CPU对相同的操作只执行一次&#xff0c;后面再遇到直接去获取即可&#xff0c;这样大大降低了CPU的开销…

【AI战略思考5】工欲善其事,必先利其器。我的利器是什么?

目录 导言1.不要忽视时间本身复利的巨大威力2.只赚自己认知以内的钱&#xff0c;只把握自己能力以内的机会3.多做有难度的事来激发自己的潜力和提升自己4.学会抵制诱惑5.减少冗余思考和冗余操作 导言 工欲善其事&#xff0c;必先利其器。我的利器是什么&#xff1f; 虽然我中考…