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

B3930 [GESP202312 五级] 烹饪问题

题目描述

有 种食材,编号从 至 ,其中第 种食材的美味度为 。

不同食材之间的组合可能产生奇妙的化学反应。具体来说,如果两种食材的美味度分别为 和 ,那么它们的契合度为 。

其中, 运算为按位与运算,需要先将两个运算数转换为二进制,然后在高位补足 ,再逐位进行与运算。例如, 与 的二进制表示分别为 和 ,将它们逐位进行与运算,得到 ,转换为十进制得到 4,因此 。在 C++ 或 Python 中,可以直接使用&运算符表示与运算。

现在,请你找到契合度最高的两种食材,并输出它们的契合度。

输入格式

第一行一个整数 ,表示食材的种数。

接下来一行 个用空格隔开的整数,依次为 ,表示各种食材的美味度。

输出格式

输出一行一个整数,表示最高的契合度。

输入输出样例 #1

输入 #1

3 1 2 3

输出 #1

2

输入输出样例 #2

输入 #2

5 5 6 2 10 13

输出 #2

8

说明/提示

样例解释 1

可以编号为 的食材之间的契合度为 ,是所有食材两两之间最高的契合度。

样例解释 2

可以编号为 的食材之间的契合度为 ,是所有食材两两之间最高的契合度。

数据范围

对于 的测试点,保证 ;

对于所有测试点,保证 ,。

PART2解题思路

2.1题目解释

本题要求从个数中选出两个,是他们按位与运算结果最大。

2.2思路
  • 因为 ,所以不可以直接两两枚举(时间复杂度 )
  • 可以注意到 ,所以二进制位最多只有位
  • 二进制中高位权值大于低位
  • 所以应该优先保证高位为1,再考虑低位
  • 所以可以采用贪心策略
  • 从高位到低位进行枚举确定答案

PART3算法步骤

1.初始化答案为0

2.从高位开始枚举

  • 尝试将第一位设为1
  • 统计有多少个数满足条件
  • 如果满足的数不少于两个,更新

3.输出答案

(时间复杂度:,空间复杂度: )

PART4代码

4.1AC记录

网址:https://www.luogu.com.cn/record/277491769

4.2AC代码
#include<bits/stdc++.h> using namespace std; int main() { unsigned long long n;cin>>n;//输入食材数量 unsigned long long a[n+1]; for(unsigned long long i=1;i<=n;i++) cin>>a[i];//读入 unsigned long long ans=0;//存储最大契合度 for(long long i=30;i>=0;i--) {//从高位到低位进行枚举 unsigned long long f=ans|(1ull<<i);//尝试将此为设为1 int cnt=0; for(unsigned long long i2=1;i2<=n;i2++) {//遍历全部食材 unsigned long long j=a[i2]; unsigned long long f2=j&f; if(f2==f) { cnt++; if(cnt>=2) {//至少两个数满足条件,则此位可以取1 ans=f;//更新ans break;//因只需要寻找两个,所以可以直接跳出循环 } } } } cout<<ans;//输出答案 return 0; }
4.3注意事项
http://www.jsqmd.com/news/1091778/

相关文章:

  • 在单台电脑上实现多人分屏游戏的完整指南:NucleusCoop实战教程
  • 存储引擎内核剖析:B+Tree 与 LSM-Tree 的性能博弈,以及如何做可信的 Benchmark
  • 2026年超好用的钢格栅机构,究竟有何独特之处?
  • 读懂2026年CSP-J 初赛:题型分析、命题规律、备考路线
  • 【STL】iostream 编程:流的定义
  • 这个项目是做什么的
  • Agent 执行到一半想暂停?用 interrupt 给它设个“关卡“!
  • 如何在Mac上免费永久备份微信聊天记录:WeChatExporter完整教程
  • [MAF预定义ChatClient中间件-01]LoggingChatClient——在调用LLM前后输出日志
  • 深度解析:ToB销售学AI,最该补的是客户研究和方案表达能力
  • 企业实物资产管理:分类、核心要点与规范管控方案
  • 通用PLM根本撑不住!汽车/芯片/新能源研发的痛,它懂[特殊字符]全星研发项目管理APQP软件系统来救场
  • FDE课程: Codex+AI 编程+ SeedanceAI 视频+ AgentAI 智能体
  • 汉明码编码译码推演与验证(P124302158李晨雨)
  • 评估模块(EVM)使用指南:规避法律风险与安全合规要点
  • BUUCTF [第五空间2019 决赛]PWN5:从格式化字符串到任意地址写的实战通关
  • 深度解析TI PCM/DSD179x评估板:从电源隔离到模拟输出的高性能音频DAC设计实战
  • FanControl终极指南:三步搞定Windows风扇智能控制
  • C#摸鱼实录——IoC与DI案例详解
  • DLSS Swapper:终极游戏性能优化指南,告别卡顿从版本管理开始
  • 瓶盖视觉检测设备 缺陷刮花划伤黑点外观ccd机器视觉检测
  • ChatGPT付费陷阱预警:这5个“默认优势”其实是营销话术,附官方API成本替代方案
  • DeepEval:高效LLM评估框架的完整实战指南
  • PHP 应用 security.txt 漏洞披露实践
  • python爬虫实战项目|第100篇:爬虫技术全景回顾与未来展望
  • 让经典游戏重获新生:dxwrapper全面解决Windows 10/11兼容性问题
  • 强制访问控制的数学基石:深度拆解BLP机密性模型的设计哲学与工程遗产
  • 终极指南:三步解锁Wand专业版完整功能,告别付费订阅
  • vi 删除指定范围的行,不用再反复按 dd
  • 编写高质量 Skill 系列 -- 如何设计需求分析与用例生成的 SKILL