[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;
}
相关推荐
mjhcsp17 小时前
C++ 循环结构:控制程序重复执行的核心机制
开发语言·c++·算法
立志成为大牛的小牛17 小时前
数据结构——四十一、分块查找(索引顺序查找)(王道408)
数据结构·学习·程序人生·考研·算法
xier_ran17 小时前
深度学习:RMSprop 优化算法详解
人工智能·深度学习·算法
地平线开发者18 小时前
不同传感器前中后融合方案简介
算法·自动驾驶
地平线开发者18 小时前
征程 6X 常见 kernel panic 问题
算法·自动驾驶
com_4sapi19 小时前
2025 权威认证头部矩阵系统全景对比发布 双榜单交叉验证
大数据·c语言·人工智能·算法·矩阵·机器人
前端小L19 小时前
二分查找专题(九):“降维”的魔术!将二维矩阵“拉平”为一维
数据结构·算法
Jasmine_llq19 小时前
《P7516 [省选联考 2021 A/B 卷] 图函数》
算法·弗洛伊德算法·floydwarshall算法·后缀和计算
kaikaile199519 小时前
三维CT图像重建算法
算法
她说人狗殊途19 小时前
时间复杂度(按增长速度从低到高排序)包括以下几类,用于描述算法执行时间随输入规模 n 增长的变化趋势:
数据结构·算法·排序算法