POJ 2453 贪心应用

文章目录

    • 1. 题目
      • 1.1 题目链接
      • 1.2 题目大意
      • 1.3 解题思路
    • 2. Accepted 代码

1. 题目

1.1 题目链接

http://poj.org/problem?id=2453

1.2 题目大意

一个数x的二进制表示有n个1,求一个有相同个数1的二进制数(比x大,且要最小的)

1.3 解题思路

  • 求出该数的二进制表示
  • 从低位往高位找到第一个为1的位 i ,检查其下一位 i+1
  • i+1 位值为 0,直接交换01,结束查找
  • i+1 位值为1,将 i 位的1不断地与前面的交换,换至最低位
  • 重复以上过程

2. Accepted 代码

在这里插入图片描述

/*** @description: 贪心应用poj2453* @author: michael ming* @date: 2019/7/2 20:46* @modified by:*/
#include <cstring>
#include <iostream>
using namespace std;int calc(int num, int *binarynum)
{int i = 0, j, k, value = 0;while(num != 0){binarynum[i++] = num % 2;//数组存储的是该数的二进制的反序序列num = num/2;}k = i;//k记录最后一个有效位的下一位for(i = 0; i < k; ++i){if(binarynum[i] == 0)continue;//找到为1的iif(binarynum[i+1] == 0)//如果i的下一个为0{swap(binarynum[i],binarynum[i+1]);//交换完成寻找break;}for(j = i; j >= 1; --j)//否则将i处的1换到最开始{swap(binarynum[j],binarynum[j-1]);}}for(i = k; i >= 0; --i)//计算对应的10进制数值//最后一位k-1可能进位到k,所以i从k开始value = value*2 + binarynum[i];return value;
}
int main()
{int binarynum[30];//数据大小不会超过30位2进制int num;while(cin >> num && num){memset(binarynum,0,30*sizeof(int));cout << calc(num,binarynum) << endl;}return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

leetcode--数组(Medium1)

2019.08.05 3.无重复字符的最长字串 基本思想&#xff1a;双指针、哈希表实现&#xff1a; 使用 head 指向无重复子串的头&#xff0c;ind 指向当前位置&#xff08;即当前无重复子串的尾&#xff09;&#xff0c;len_max记录当前无重复字串的最长长度&#xff0c;使用字典的 …

ICML2020 | 一行代码就能实现的测试集上分技巧

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术文 | 苏剑林编 | 夕小瑶在训练模型的时候&#xff0c;我们需要损失函数一直训练到0吗&#xff1f;显然不用。一般来说&#xff0c;我们是用训练集来训练模型&#xff0c;但希望的是验证集的损失越小越好&…

Redis系列教程(七):Redis并发竞争key的解决方案详解

Redis高并发的问题 Redis缓存的高性能有目共睹&#xff0c;应用的场景也是非常广泛&#xff0c;但是在高并发的场景下&#xff0c;也会出现问题&#xff1a; 高并发架构系列&#xff1a;Redis缓存和MySQL数据一致性方案详解 如何解决Redis缓存雪崩、缓存穿透、缓存并发等5大难…

技术动态 | 北京大学计算机所邹磊教授研究组开源面向 RDF 知识图谱的自然语言问答系统 gAnswer...

项目网站: http://ganswer.gstore-pku.com/代码地址: https://github.com/pkumod/gAnswerOpenKG发布地址: http://openkg.cn/tool/ganswer研究组主页: http://mod.icst.pku.edu.cn一、KBQA 任务简介基于知识库的自然语言问答 (Question Answering over Knowledge Base, KBQA) 主…

SQL简明数据分析教程

https://blog.csdn.net/heming6666/article/details/78207476 实际案例分析&#xff1a; 一道简单的sql语句题 https://cloud.tencent.com/developer/article/1092199

POJ 2287 田忌赛马(贪心)

文章目录1. 题目1.1 题目链接1.2 题目大意1.3 解题思路2. Accepted 代码1. 题目 1.1 题目链接 http://poj.org/problem?id2287 1.2 题目大意 双方各有n匹战斗力各异的马&#xff0c;分别派出来PK&#xff0c;假设对方先出牌&#xff0c;我方后出&#xff0c;求我方最多能胜…

Python中的 List

关于List&#xff1a;最最最基本操作其他操作上的问题一、如何判断 list 重复二、根据 list 里面的每一个 list 的第一个元素排序三、 一个 list 给另一个 list 赋值四、list 与 nparray五、二维列表按列取元素报错汇总IndexError:list assignment Index out of rangeValueErro…

Netty的实现原理、特点与优势、以及适用场景

高并发编程系列 高并发编程系列&#xff1a;NIO、BIO、AIO的区别&#xff0c;及NIO的应用和框架选型 高并发编程系列&#xff1a;ConcurrentHashMap的实现原理(JDK1.7和JDK1.8) 高并发编程系列&#xff1a;CountDownLatch、Semaphore等4大并发工具类详解 高并发编程系列&…

拒绝无脑吹!从ACL20看预训练缺陷

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术文 | 舒意恒、兔子酱以 BERT 为代表作的预训练模型的研究热度一直很高&#xff0c;到 0202 年了&#xff0c;预训练的研究依旧层出不穷&#xff0c;而且 ACL 2020 Best Paper 荣誉提名也选择了这一主题的研究…

论文浅尝 | AMUSE: 基于 RDF 数据的多语言问答语义解析方法

来源&#xff1a;ISWC 2017链接&#xff1a;https://link.springer.com/content/pdf/10.1007%2F978-3-319-68288-4.pdf本文主要关注基于RDF数据的多语言问答任务中&#xff0c;对不同语言问句的语义分析工作。作者提出一种基于DUDES(Dependency-based Underspecified Discourse…

网易2018

网易2018数据分析&#xff08;20道单选3道问答&#xff09; 好评率是会员对平台评价的重要指标。现在需要统计2018年1月1日到2018年1月31日&#xff0c;用户’小明’提交的母婴类目"花王"品牌的好评率&#xff08;好评率“好评”评价量/总评价量&#xff09;: 用户评…

贪心应用--汽车加油次数问题

文章目录1. 问题描述2. 解题思路3. 实现代码4. 测试结果1. 问题描述 已知汽车的油箱额定里程&#xff0c;到目的地的路途中各加油站距起点的距离&#xff0c;求如何加油&#xff0c;让加油的次数最少。 2. 解题思路 每次出发前检查下一个加油站有多远&#xff0c;车子能不能…

Pandas中的元素替换

# 序列中的元素替换 ser pd.Series([0, 1, 2, 3, 4, 5]) print(ser.replace(0, 6)) # 单个元素替换 print(ser.replace([0, 1, 2, 3, 4, 5], [5, 4, 3, 2, 1, 0])) # 列表替换 print(ser.replace({1: 11, 2: 22})) # 字典替换# DataFram中的元素替换 df pd.DataFrame({&qu…

最全多线程经典面试题和答案

Java实现线程有哪几种方式&#xff1f; 1、继承Thread类实现多线程2、实现Runnable接口方式实现多线程3、使用ExecutorService、Callable、Future实现有返回结果的多线程 多线程同步有哪几种方法&#xff1f; Synchronized关键字&#xff0c;Lock锁实现&#xff0c;分布式锁等…

论文浅尝 | Aligning Knowledge Base and Document Embedding Models

本文是我们于苏黎世大学合作的关注与知识图谱和文本对齐的论文&#xff0c;发表于ISWC2018.文本和知识图谱都包含了丰富的信息, 其中知识图谱用结构化的三元组表示信息&#xff0c;文本用自由文本形式表示信息&#xff0c;信息表示的差异给知识图谱和文本融合对齐造成了困难&am…

学会提问的BERT:端到端地从篇章中构建问答对

星标/置顶小屋&#xff0c;带你解锁最萌最前沿的NLP、搜索与推荐技术文 | 苏剑林机器阅读理解任务&#xff0c;相比不少读者都有所了解了&#xff0c;简单来说就是从给定篇章中寻找给定问题的答案&#xff0c;即“篇章 问题 → 答案”这样的流程&#xff0c;笔者之前也写过一些…

leetcode--数组(Medium2)

2019.08.09 39.组合总数 基本思想&#xff1a;回溯实现&#xff1a; def combinationSum(self, candidates: List[int], target: int) -> List[List[int]]:candidates.sort()n len(candidates)res []def helper(i, tmp_sum, tmp):if tmp_sum > target or i n:return …

玩转算法面试-第四章查找值之leetcod相关笔记

查找问题 4-1,2 两类查找问题 1 查找有无&#xff1a;set 2 查找对应关系&#xff1a;map 常见的四种操作&#xff1a; insert&#xff0c; find&#xff0c; erase&#xff0c; change&#xff08;map&#xff09; 例题 leetcode 349 &#xff1a;给定两个数组&#xff0c;…

分治算法(Divide Conquer)

文章目录1. 分治算法思想2. 应用举例2.1 逆序度3. 分治思想处理海量数据1. 分治算法思想 分治算法的核心思想就是&#xff0c;分而治之&#xff0c;将原问题划分成n个规模较小&#xff0c;并且结构与原问题相似的子问题&#xff0c;递归地解决这些子问题&#xff0c;然后再合并…

史上最全Java多线程面试60题,含答案大赠送!

【BAT必考系列&#xff01;多线程60题】 多线程有什么用&#xff1f; 线程和进程的区别是什么&#xff1f; ava实现线程有哪几种方式&#xff1f; 启动线程方法start&#xff08;&#xff09;和run&#xff08;&#xff09;有什么区别&#xff1f; 怎么终止一个线程&#…