[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;
}
相关推荐
小饼干超人13 小时前
详解向量数据库中的PQ算法(Product Quantization)
人工智能·算法·机器学习
你撅嘴真丑14 小时前
第四章 函数与递归
算法·uva
漫随流水14 小时前
leetcode回溯算法(77.组合)
数据结构·算法·leetcode·回溯算法
玄冥剑尊14 小时前
动态规划入门
算法·动态规划·代理模式
mjhcsp14 小时前
P14987 全等(mjhcsp)
算法·题解·洛谷
(❁´◡`❁)Jimmy(❁´◡`❁)14 小时前
Atcoder abc441A~F 题解
算法·深度优先·图论
少林码僧14 小时前
2.30 传统行业预测神器:为什么GBDT系列算法在企业中最受欢迎
开发语言·人工智能·算法·机器学习·ai·数据分析
豆沙沙包?14 小时前
2026年--Lc343-1926. 迷宫中离入口最近的出口(图 - 广度优先搜索)--java版
java·算法·宽度优先
超级大福宝15 小时前
【力扣200. 岛屿数量】的一种错误解法(BFS)
数据结构·c++·算法·leetcode·广度优先
独自破碎E15 小时前
【动态规划=递归+记忆化存储】跳台阶
算法·动态规划