当前位置: 首页 > wzjs >正文

图书馆管理网站建设logo网络推广公司排名

图书馆管理网站建设logo,网络推广公司排名,梧州网站开发,h5网站开发费用问题背景 给你一个下标从 0 0 0 开始长度为 n n n 的整数数组 n u m s nums nums 和一个整数 k k k。每一次操作中,你可以选择一个数并将它乘 2 2 2。 你最多可以进行 k k k 次操作,请你返回 n u m s [ 0 ] ∣ n u m s [ 1 ] ∣ . . . ∣ n u m …

问题背景

给你一个下标从 0 0 0 开始长度为 n n n 的整数数组 n u m s nums nums 和一个整数 k k k。每一次操作中,你可以选择一个数并将它乘 2 2 2
你最多可以进行 k k k 次操作,请你返回 n u m s [ 0 ] ∣ n u m s [ 1 ] ∣ . . . ∣ n u m s [ n − 1 ] nums[0] | nums[1] | ... | nums[n - 1] nums[0]nums[1]∣...∣nums[n1] 的最大值。
a ∣ b a | b ab 表示两个整数 a a a b b b按位或 运算。

数据约束

  • 1 ≤ n u m s . l e n g t h ≤ 1 0 5 1 \le nums.length \le 10 ^ 5 1nums.length105
  • 1 ≤ n u m s [ i ] ≤ 1 0 9 1 \le nums[i] \le 10 ^ 9 1nums[i]109
  • 1 ≤ k ≤ 15 1 \le k \le 15 1k15

解题过程

要求最终或运算的结果最大,应该尽可能地增加它的二进制长度。
2 2 2 和左移是完全等价的,集中对一个数进行不断地左移要比对多个数分散操作更有可能增加数字的二进制长度。
所以只需要遍历并讨论对每个数字进行操作得到的结果,取最大值即可。
要快速计算某个位置上的或运算结果,除了它本身左移之后的数值,还需要它的前后缀或运算结果。为了快速计算,可以先处理好前后缀的值。

具体实现

class Solution {public long maximumOr(int[] nums, int k) {int n = nums.length;int[] sufOrSum = new int[n];for (int i = n - 2; i >= 0; i--) {sufOrSum[i] = sufOrSum[i + 1] | nums[i + 1];}long res = 0;int preOrSum = 0;for (int i = 0; i < n; i++) {res = Math.max(res, preOrSum | ((long) nums[i] << k) | sufOrSum[i]);preOrSum |= nums[i];}return res;}
}
http://www.dtcms.com/wzjs/407094.html

相关文章:

  • 做网站 0元代理成都搜狗seo
  • 阿里巴巴网站更新怎么做石家庄网站seo外包
  • 阿里巴巴网站怎么做学生个人网页制作教程
  • 免费的行情网站推荐下载安装百度搜索引擎首页
  • 成都科技网站建设费深圳全网营销推广平台
  • 设计日本网站免费的发帖收录网站
  • 迁安网站建设小程序开发流程
  • 自助免费网站制作策划品牌全案
  • php网站整合dz论坛网站建设优化推广
  • 上海企业响应式网站建设推荐国外网站如何搭建网页
  • 点开文字进入网站是怎么做的常见的网络推广方法有哪些
  • app网站建设教程视频教程百度广告位价格
  • 企业网站建设哪里做网站好如何注册网站
  • 做视频网站是什么职业关键词搜索排名怎么查看
  • 台州卓远做网站好不好谷歌浏览器app下载安装
  • 在哪个网站做销售比较好建立免费个人网站
  • 什么网站可以做兼职销售电商平台推广方式有哪些
  • 在线网页游戏网站网店推广有哪些
  • 房产官方网站灰色词快速排名方法
  • 西安做网站要多少钱b站推广网站2022
  • 网站怎么加关键词做优化优化网站推广
  • 北京企业建设网站百度站长快速收录
  • 网站权重为零佛山百度快速排名优化
  • 广州php网站建设接app推广
  • seo培训教程济南网络seo公司
  • 网站建设单子seo关键词优化公司哪家好
  • 门窗设计软件免费版seo牛人
  • 商丘做网站的费用seo超级外链工具
  • 上海企业排行榜网站优化排名首页
  • 上海疫情饿死了多少人网站seo 工具