[GESP202312 五级] 烹饪问题

视频讲解:[GESP202312 五级] 烹饪问题-信息学奥赛GESP等级考试真题解析

一、原题

题目描述

有 N 种食材,编号从 1 至 N,其中第 i 种食材的美味度为 ai​。

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

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

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

输入格式

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

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

输出格式

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

输入输出样例

输入 #1

复制代码
3
1 2 3

输出 #1

复制代码
2

输入 #2

复制代码
5
5 6 2 10 13

输出 #2

复制代码
8

说明/提示

样例解释 1

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

样例解释 2

可以编号为 3,4 的食材之间的契合度为 10 and 13=8,是所有食材两两之间最高的契合度。

数据范围

对于 40% 的测试点,保证 N ≤ 1,000;

对于所有测试点,保证 N ≤ ,0 ≤ ai​ ≤ 2,147,483,647。

二、做题思路

1)填充数据

cpp 复制代码
//1)填充数据
//1.1)确定食材种类n
int n;cin>>n;
//1.2)填充每种食材的美味度
vector<int> foods;
for(int i=1;i<=n;i++){
    int temp;
    cin>>temp;
    foods.push_back(temp);
} 

2)寻找契合度最高的食材

cpp 复制代码
//2)寻找契合度最高的食材
	int max_val=0;
	//2.1)从权重最高的31开始 
	for(int i=30;i>=0;i--){
		//2.2)保证之前的契合度 
		int now=max_val|(1<<i);
		//2.3)判断当前权重出现是否超过2 
		int count=0;
		for(auto it:foods){
			if((it&now)==now){
				count++;
			}
			if(count>=2){
				break;
			}
		}
		//2.4)权重出现超过2,更新最大契合度 
		if(count>=2){
			max_val=now;
		}
	}

三、答案

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
	//1)填充数据
	//1.1)确定食材种类n
	int n;cin>>n;
	//1.2)填充每种食材的美味度
	vector<int> foods;
	for(int i=1;i<=n;i++){
		int temp;
		cin>>temp;
		foods.push_back(temp);
	} 
	//2)寻找契合度最高的食材
	int max_val=0;
	//2.1)从权重最高的31开始 
	for(int i=30;i>=0;i--){
		//2.2)保证之前的契合度 
		int now=max_val|(1<<i);
		//2.3)判断当前权重出现是否超过2 
		int count=0;
		for(auto it:foods){
			if((it&now)==now){
				count++;
			}
			if(count>=2){
				break;
			}
		}
		//2.4)权重出现超过2,更新最大契合度 
		if(count>=2){
			max_val=now;
		}
	}
	//3)输出 
	cout<<max_val;
}
相关推荐
海清河晏11111 分钟前
数据结构 | 单循环链表
数据结构·算法·链表
wuweijianlove4 小时前
算法性能的渐近与非渐近行为对比的技术4
算法
_dindong4 小时前
cf1091div2 C.Grid Covering(数论)
c++·算法
AI成长日志4 小时前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
黎阳之光5 小时前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
skywalker_115 小时前
力扣hot100-3(最长连续序列),4(移动零)
数据结构·算法·leetcode
6Hzlia5 小时前
【Hot 100 刷题计划】 LeetCode 17. 电话号码的字母组合 | C++ 回溯算法经典模板
c++·算法·leetcode
wfbcg5 小时前
每日算法练习:LeetCode 209. 长度最小的子数组 ✅
算法·leetcode·职场和发展
_日拱一卒6 小时前
LeetCode:除了自身以外数组的乘积
数据结构·算法·leetcode
计算机安禾6 小时前
【数据结构与算法】第36篇:排序大总结:稳定性、时间复杂度与适用场景
c语言·数据结构·c++·算法·链表·线性回归·visual studio