开发者社区> 问答> 正文

遇到一个2的幂次方数问题,求解答。

Tom是一个十分喜欢数学的人,尤其喜欢2的幂次方的数字。现有n(1<=n<=150000)个数字,对于其中的每一个数字 ai(1<=i 输入数字个数 n 和 n 个数字;输出一个数字,表示最终需要删除的数字的个数。

展开
收起
游客4skzfvnrxrzbi 2021-12-23 16:55:23 597 0
1 条回答
写回答
取消 提交回答
  • 对于本题,因为要从数组中删除数字。删除分为两步,一是定位(查找),二是删除(将出现次数减 1)。所以首先需要考虑的难题是,如何快速定位要查找的数字,并记录下数字出现的次数? for 循环的线性查找,递归的二分查找(对有序数组),建立哈希表,都是可选的方式。既然追求最佳解法,你不妨先试试将题目提供的数据结构转为哈希表?之后的第二个难点,就是如何得出“与某个数相加为 2 的幂次方数”的数字了。我们知道,用二进制表示时,一个2的幂次方的正整数,譬如2,4,8,16...,只有最高位为 1,其余位都是 0,譬如 b1,b10,b100,b1000... 所以,对每个数字,只要用位元算找到它的最高位 1 的位置,就可以确定比它大的 2 的幂次方数中最小的数字了。本题最后的陷阱,在于正确理解“与这个数相加为 2 的幂次方数”的条件。举个例子来说,对于数字1,它不仅与1相加为2的幂次方数,与3,7,15...相加后,结果都是 2 的幂次方数。很多同学想到位运算的时候,可能忽略了这个条件,而只考虑了比数字大的 2 的幂次方数中最小的数字3 输入:3 [1,2,3] 输出:1

    2021-12-23 18:46:23
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载