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

目录

蓝桥杯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;
}
相关推荐
念越3 小时前
蓝桥杯17届功能测试模拟1期题目及解析(1)
功能测试·蓝桥杯·测试用例·场景法
C++ 老炮儿的技术栈3 小时前
volatile使用场景
linux·服务器·c语言·开发语言·c++
AI科技星4 小时前
全尺度角速度统一:基于 v ≡ c 的纯推导与验证
c语言·开发语言·人工智能·opencv·算法·机器学习·数据挖掘
always_TT6 小时前
C语言中的字符与字符串(char数组)
c语言·开发语言
forAllforMe6 小时前
LAN9252 从机寄存器配置--C语言举例
c语言·开发语言
17(无规则自律)6 小时前
【Linux驱动实战】:字符设备之ioctl与mutex全解析
linux·c语言·驱动开发·嵌入式硬件
weixin_537590456 小时前
《C程序设计语言》练习答案(练习1-4)
c语言·开发语言
炸膛坦客7 小时前
单片机/C/C++八股:(十五)内存对齐、结构体内存对齐
c语言·开发语言·单片机
老约家的可汗7 小时前
C/C++内存管理探秘:从内存分布到new/delete的底层原理
c语言·c++
计算机安禾7 小时前
【C语言程序设计】第37篇:链表数据结构(一):单向链表的实现
c语言·开发语言·数据结构·c++·算法·链表·蓝桥杯