蓝桥杯2023年第十四届省赛真题-买瓜--C语言题解

news/2024/7/7 21:32:15

目录

蓝桥杯2023年第十四届省赛真题-买瓜

题目描述

输入格式

输出格式

样例输入

样例输出

提示

【思路解析】

【代码实现】


蓝桥杯2023年第十四届省赛真题-买瓜

时间限制: 3s 内存限制: 320MB 提交: 796 解决: 69

题目描述

小蓝正在一个瓜摊上买瓜。瓜摊上共有 n 个瓜,每个瓜的重量为 Ai 。

小蓝刀功了得,他可以把任何瓜劈成完全等重的两份,不过每个瓜只能劈一刀。

小蓝希望买到的瓜的重量的和恰好为 m 。

请问小蓝至少要劈多少个瓜才能买到重量恰好为 m 的瓜。如果无论怎样小蓝都无法得到总重恰好为 m 的瓜,请输出 −1 。

输入格式

输入的第一行包含两个整数 n, m,用一个空格分隔,分别表示瓜的个数和小蓝想买到的瓜的总重量。

第二行包含 n 个整数 Ai,相邻整数之间使用一个空格分隔,分别表示每个瓜的重量。

输出格式

输出一行包含一个整数表示答案。

样例输入

复制

3 10
1 3 13

样例输出

复制

2

提示

对于 20% 的评测用例,∑n≤10;

对于 60% 的评测用例,∑n≤20;

对于所有评测用例,1 ≤n≤30,1≤ Ai ≤ 109 ,1 ≤ m ≤ 10^9

【思路解析】

这道题是一个很简单的递归可能性的罗列,但是每次递归有三个情况,则时间复杂度为O(3^N),时间复杂度过高,所以需要在递归过程中除掉那些完全不可能的解,使复杂度降低。

【代码实现】

#include<stdio.h>
int n = 0, m = 0, nums[30], min = 100;
long suf[31];
int dfs(int i, double sum, int c) {
	if (c >= min) return 100;         // 劈瓜的次数大于等于最小值,即使能满足要求m也没有意义,因为它不是最小的
	if (sum == m) {
        min = c;
        return c;
    }
    if (sum > m) return 100;          // 如果当前sum大于m,即可提前结束
	if (i == n) {
        return 100; //此时已经使用了所有西瓜,也无法满足,直接排除掉
   }
    if (suf[i] + sum < m) return 100; // 如果当前sum加上剩余所有值都小于m,即可提前结束
    int a = dfs(i + 1, sum + nums[i], c); // 全拿走 
    int b = dfs(i + 1, sum + (nums[i] / 2.0), c + 1); // 拿走一半 
    int f = dfs(i + 1, sum, c);  // 不拿走 
	int k = mins(b, f);
    return mins(a, k);
}
int mins(int a, int b){
	return a > b? b :a;
}
int main(){
        scanf("%d %d", &n, &m);
        int i = 0;
        for (i = 0; i < n; i++) {
            scanf("%d", &nums[i]);
        }
        for (i = n - 1; i >= 0; i--) {
            suf[i] = suf[i + 1] + nums[i];
        }
        int m = dfs(0, 0, 0);
        if (m == 100)
            printf("-1");
        else{
        	printf("%d\n",m);
		}
        return 0;
}


http://lihuaxi.xjx100.cn/news/1561261.html

相关文章

华为云云耀云服务器L实例评测|docker私有仓库部署手册

【软件安装版本】【集群安装&#xff08;是&#xff09;&#xff08;否&#xff09;】 版本号 文档编写 文档审核 创建日期 修改日期 1.0 jzg jzg 2023.9.13 一. 部署规划与架构 1. 规划&#xff1a;&#xff08;集群&#xff1a;网络规划&…

【游戏技术】求生之路1支持2代官方地图方法

支持求生之路L4D1支持2代官方内容 程序制作1.2.三级目录 程序制作 1. 2.三级目录

c++ 归并排序

归并排序算法时间复杂度较为稳定&#xff0c;一般为nlogn,而快速排序受源数组排序影响较大&#xff0c;今天来学习归并排序。 一.归并排序代码 首先上代码&#xff1a;可以直接运行 #include<bits/stdc.h> using namespace std;void insertsort(vector<int>&…

堆和树的区别

“堆” 这个术语在计算机科学中指的是一种特定类型的数据结构&#xff0c;它满足一些特定的性质&#xff0c;主要用于实现优先队列和相关算法。虽然堆通常以树的形式呈现&#xff0c;但它们与通常的树结构有一些重要的区别&#xff0c;因此被单独命名为 “堆” 而不是 “树”。…

ruoyi-nbcio移植过程中的一些问题记录

1、打包去掉测试出现 Failed to execute goal org.apache.maven.plugins:maven-surefire-plugin:2.22.2:test 错误 在pom.xml里增加下面 去掉测试 <!--添加配置跳过测试--> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId…

MySQL数据库入门到精通1--基础篇(MySQL概述,SQL)

1. MySQL概述 1.1 数据库相关概念 目前主流的关系型数据库管理系统&#xff1a; Oracle&#xff1a;大型的收费数据库&#xff0c;Oracle公司产品&#xff0c;价格昂贵。 MySQL&#xff1a;开源免费的中小型数据库&#xff0c;后来Sun公司收购了MySQL&#xff0c;而Oracle又收…

Android 匿名共享内存的使用

注&#xff1a;本文内容转载自如下文章&#xff1a;Android 匿名共享内存的使用 Android View 的绘制是如何把数据传递给 SurfaceFlinger 的呢&#xff1f; 跨进程通信时&#xff0c;数据量大于1MB要怎么传递呢&#xff1f;用 匿名共享内存&#xff08;Ashmem&#xff09; 是个…

uniapp开发h5,解决项目启动时,Network: unavailable问题

网上搜了很多&#xff0c;发现都说是要禁用掉电脑多余的网卡&#xff0c;这方法我试了没有好&#xff0c;不晓得为啥子&#xff0c;之后在网上看&#xff0c;uniapp的devServer vue2的话对标的就是webpack4的devserver&#xff08;除了复杂的函数配置项&#xff09;&#xff0c…