当前位置: 首页 > news >正文

算法每日一题:P2089 烤鸡 -DFS练习

在这里插入图片描述

😚一个不甘平凡的普通人,日更算法学习和打卡,期待您的关注和认可,陪您一起学习打卡!!!😘😘😘
🤗专栏:每日算法学习
💬个人主页:个人主页

算法分类:dfs练习
语言:java
题目来源:洛谷 P2089 烤鸡

文章目录

  • 烤鸡
    • 题目背景
    • 题目描述
    • 输入格式
    • 输出格式
    • 样例 #1
      • 样例输入 #1
      • 样例输出 #1
    • 提示
  • 思路
  • 完整代码:
  • 结果

烤鸡

题目背景

猪猪 Hanke 得到了一只鸡。

题目描述

猪猪 Hanke 特别喜欢吃烤鸡(本是同畜牲,相煎何太急!)Hanke 吃鸡很特别,为什么特别呢?因为他有 101010 种配料(芥末、孜然等),每种配料可以放 111333 克,任意烤鸡的美味程度为所有配料质量之和。

现在, Hanke 想要知道,如果给你一个美味程度 nnn ,请输出这 101010 种配料的所有搭配方案。

输入格式

一个正整数 nnn,表示美味程度。

输出格式

第一行,方案总数。

第二行至结束,101010 个数,表示每种配料所放的质量,按字典序排列。

如果没有符合要求的方法,就只要在第一行输出一个 000

样例 #1

样例输入 #1

11

样例输出 #1

10
1 1 1 1 1 1 1 1 1 2 
1 1 1 1 1 1 1 1 2 1 
1 1 1 1 1 1 1 2 1 1 
1 1 1 1 1 1 2 1 1 1 
1 1 1 1 1 2 1 1 1 1 
1 1 1 1 2 1 1 1 1 1 
1 1 1 2 1 1 1 1 1 1 
1 1 2 1 1 1 1 1 1 1 
1 2 1 1 1 1 1 1 1 1 
2 1 1 1 1 1 1 1 1 1

提示

对于 100%100\%100% 的数据,n≤5000n \leq 5000n5000

思路

每种佐料有三种情况,所以总的情况不会超过3^10,我们枚举每一种情况,定义一个数组来每种方案内佐料的质量,定义一个sum来统计总重,作为回溯的条件,最后输出即可。

完整代码:

import java.util.Scanner;public class Main {//方案数static int res;//存储static int count;static int arr[];static int hello[][] = new int [59050][11];static int N;public static void main(String[] args) {Scanner  s = new Scanner(System.in);N = s.nextInt();arr = new int [20];dfs(1,0);System.out.println(res);for(int i =1;i<=res;i++) {for(int j =1;j<=10;j++) {System.out.print(hello[i][j]+" ");}System.out.println();}}public static void dfs(int index,int sum) {if(sum>N) return;if(index>10) {if(sum ==N) {res++;for(int i=1;i<=10;i++) {hello[res][i] = arr[i];}}return ;}for(int i =1;i<=3;i++) {arr[index] = i;dfs(index+1, sum+i);arr[index] =0;}}
}

结果

在这里插入图片描述

感谢您的阅读,希望对您有所帮助。关注我,完成每日算法自律打卡,什么时候开始都不晚!!

http://www.lryc.cn/news/58368.html

相关文章:

  • Spring中的循环依赖是什么?如何解决它?
  • 不良事件报告系统源码,PHP医院安全(不良)事件报告系统源码,在大型医院稳定运行多年
  • MySQL 查询常用操作(3)——排序 order by
  • Android Jetpack 从使用到源码深耕【数据库注解Room 从实践到原理 】(二)
  • 传统企业如何实现数字化转型?
  • Linux修改密码报错Authentication token manipulation error的终极解决方法
  • ROS实践06 自定义消息类型
  • 《剑指offer》——从尾到头打印链表
  • Javaweb基础配置模板(mybatis+javaweb)
  • 物联网 JS 前端框架开发 - 执行 js 程序
  • 区块链概论
  • MAC地址表安全
  • 处理CSV(python)
  • 【云原生】Kubernetes(k8s)之容器的探测
  • 看完这个你就牛了,自动化测试框架设计
  • Spring Cloud Alibaba全家桶(八)——Sentinel规则持久化
  • Mysql不锁表备份之Xtrabackup的备份与恢复
  • flex布局:输入框布局demo
  • PHP请求的好处,PHP如何请求淘宝开放接口
  • 精选出来的几道Java语法基础面试题
  • uniapp或者小程序图片选择中的sizeType属性到底是什么
  • 判断一个字符串是否是回文
  • 国产软件爆发!中国版Navicat,SQL Studio成数据库管理工具热门
  • 算法学习day51
  • 10 JS01——初识JS
  • 【软考备考-综合知识】安全性、可靠性与系统性能评测基础知识
  • 匆忙之间难免疏忽,写代码更加如此
  • 低代码(七)低代码平台后端技术选型2.0
  • UDS介绍
  • ASP.NET Core MVC 从入门到精通之初窥门径