蓝桥杯-dfs(一)

news/2024/7/20 20:28:19 标签: 深度优先, 蓝桥杯, 算法, java

📑前言

本文主要是【算法】——dfs使用的文章,如果有什么需要改进的地方还请大佬指出⛺️

🎬作者简介:大家好,我是听风与他🥇
☁️博客首页:CSDN主页听风与他
🌄每日一句:狠狠沉淀,顶峰相见

目录

    • 📑前言
    • dfs-剪枝
    • dfs-整数划分
    • 📑文章末尾

dfs-剪枝

  • 整数n划分成k份的方案
java">package 搜索;

import java.util.Scanner;

public class dfs_剪枝 {

	static int ans;//记录总次数
	static int cnt;
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner sc = new Scanner(System.in);
		while(sc.hasNext()) {
			int n = sc.nextInt();
			int k = sc.nextInt();
			ans=0;
			cnt=0;
			dfs(n, k, 1, "");
			System.out.println("方案数"+ans);
			System.out.println("调用次数"+cnt);
		}
	}
	/**
	 * 整数n划分成k份的方案
	 * @param n 待划分的数
	 * @param k 份数
	 * @param min 要保证唯一 1 1 5 和 5 1 1 是等价的,构建非降序,min是目前被拆分使用的最大的数
	 * @param fanan 记录详细划分的方案数
	 */
	public static void dfs(int n,int k,int min,String fanan) {
		cnt++;//只要进入dfs,调用次数就+1
		if(k==1 && min<=n) {
			ans++;
			System.out.println(fanan+n);
			return;
		}
		if(min*k>n) return; 
		for(int i=min;i<=n;i++) {
			dfs(n-i, k-1, i, fanan+i+"+");
		}
	}

}

dfs-整数划分

java">package 搜索;

public class dfs_整数划分 {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		dfs(4, 0, 0, "");
	}
	
	/**
	 * DFS模拟整数的划分
	 * @param n 要拆分的原始的数
	 * @param nowget 目前已经得到的值,到n就game over
	 * @param maxused 实时的记录目前拆分已经用到的最大值 4 = 3 + 1
	 * @param ans 具体的拆分方案
	 */
	public static void dfs(int n,int nowget,int maxused,String ans) {
		if(nowget==n) {
			System.out.println(ans.substring(0, ans.length()-1));
			return;
		}
		for(int i=1;i<=n-nowget;i++) {//目标累加到n,已经累加到了nowget
			if(i>=maxused)dfs(n, nowget+i, i, ans+i+"+");
		}
	}
}

📑文章末尾

在这里插入图片描述


http://www.niftyadmin.cn/n/5337764.html

相关文章

// doesn‘t exist

- // doesnt exist 13.3 赋给派生类引用,将发生什么情况呢?派生类引用能够为基对象调用派生类方法,这样做将出现问题。例 如,将RatedPlayer :: Rating()方法用于TableTennisPlayer对象是没有意义的,因为TableTennisPlayer对象没 有rating成员。 如果基类引用和指针可以指向…

vue3-模版引用

模版引用 ref 属性 场景&#xff1a;需要直接访问底层 DOM 元素。 方法&#xff1a;使用特殊的 ref 属性。 <input ref"input">ref 属性 允许我们在一个特定的 DOM 元素或子组件实例被挂载后&#xff0c;获得对它的直接引用。 访问模板引用 小 Demo: 当 i…

Jetson Orin Nano使用OpenCV获取视频帧率和帧数的方法

测试过程 首先确认下视频的播放时间 使用cv库来获取帧率和帧数&#xff0c;测试代码如下 import cv2 cap cv2.VideoCapture("xxx.mp4") if not cap.isOpened():print("Cannot open camera")exit()# get default video FPS fps cap.get(cv2.CAP_PROP_F…

二叉树基础oj题目

二叉树基础oj题目及思路总结 前文中&#xff0c;介绍了二叉树的基本概念及基础操作&#xff0c;进一步对于二叉树的递归遍历及子问题的处理思想有了一定的了解。本文将带来几道二叉树经典的oj题目。 目录 二叉树基础oj题目 对称二叉树平衡二叉树二叉树的层序遍历 二叉树基…

【精选】中间件 tomcat漏洞复现

&#x1f36c; 博主介绍&#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 hacker-routing &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【应急响应】 【python】 【VulnHub靶场复现】【面试分析】 &#x1f389;点赞➕评论➕收藏…

MySQL - 使用 MySQL 存储过程来生成大量数据并插入到 MySQL 数据库中

可以使用 MySQL 存储过程来生成大量数据并插入到 MySQL 数据库中。下面是一个示例存储过程&#xff0c;它可以生成指定数量的模拟用户数据并将其插入到名为 users 的表中。 DELIMITER // CREATE PROCEDURE generate_fake_users(IN num_rows INT) BEGINDECLARE i INT DEFAULT 1…

Repository docker-ce-test is listed more than once in the configuration

这个消息表明&#xff0c;在你的 CentOS 系统的 YUM 软件源配置中&#xff0c;docker-ce-stable、docker-ce-stable-source 和 docker-ce-test 这几个仓库被列出了多次。这通常发生在 /etc/yum.repos.d/ 目录下的 YUM 配置文件中&#xff0c;相同的仓库被重复添加。 这种情况可…

Qt简单使用与初识

&#x1f307;个人主页&#xff1a;平凡的小苏 &#x1f4da;学习格言&#xff1a;命运给你一个低的起点&#xff0c;是想看你精彩的翻盘&#xff0c;而不是让你自甘堕落&#xff0c;脚下的路虽然难走&#xff0c;但我还能走&#xff0c;比起向阳而生&#xff0c;我更想尝试逆风…