P8599 [蓝桥杯 2013 省 B] 带分数(dfs+全排列+断点判断)

思路:1.深度枚举所有排列情况

2.设置为每个排列设置两个断点,分为三部分:a,b,c

3.转换为乘法判断条件,满足加一

代码如下:(可用next_permutation全排列函数代替dfs)

复制代码
#include<iostream>
#include<stdio.h>
using namespace std;
int ans = 0;

int visit[11] = { 0 };

int arr[11] = { 0 }, k = 0;

int tonum(int l, int r) {//将num数组的第l至r个数转为一个数
	int re = 0;
	for (int i = l; i <r; i++) {
		re = re * 10 + arr[i];
	}
	return re;
}

void dec();

void dfs();

int l = 0;

int main()
{
	
	scanf("%d", &l);
	dfs();
	cout << ans << endl;
	return 0;
}
void dfs()
{
	for (int i = 1; i <= 9; i++)
	{

		if (!visit[i])
		{
			visit[i] = 1;
			arr[k++] = i;
			dfs();
			if (k == 9)		dec();
			k--;
			visit[i] = 0;
		}
	}
}

void dec()
{
	for (int i = 1; i <= 7; i++)
	{	int a = tonum(0, i);
		for (int j = i; j <= 8; j++)
		{
			int b = tonum(i, j);
			int c = tonum(j, 9);
			if ((l - a) * c == b) {
				ans++;
			}
		}
	}
}
相关推荐
仟濹15 小时前
【算法打卡day6 | 2026-02-11 周三 | 算法: BFS and BFS】| 8_卡码网104_建造最大岛屿 | 9_卡码网106_海岸线计算
算法·深度优先·广度优先·宽度优先
TracyCoder12316 小时前
LeetCode Hot100(35/100)——200. 岛屿数量
算法·leetcode·深度优先
会编程的土豆21 小时前
深度优先搜索dfs和广度优先搜索例题bfs
算法·深度优先·图论·洛谷
_OP_CHEN1 天前
【算法基础篇】(六十)Nim 博弈超全解析:从基础原理到经典变种,玩转多堆取石子问题
算法·蓝桥杯·c/c++·博弈论·算法竞赛·acm、icpc·nim博弈
近津薪荼2 天前
dfs专题6——二叉树的所有路径
c++·学习·算法·深度优先
robinson19882 天前
测试Oracle-崖山-DM-GaussDB树形查询性能
深度优先·广度优先·树形查询
觅特科技-互站2 天前
政务AI口播落地难?矩阵跃动一体机实测:本地离线+等保三级,某省大数据局3天完成信创部署
大数据·人工智能·深度优先·kmeans·政务
会编程的土豆2 天前
深度优先搜索刷题(方向数组+DFS思想):解决矩阵单词搜索问题的标准解法
算法·深度优先·图论·洛谷
BLOLCO2 天前
揭秘变色马克杯性价比之王:这家生产商为何让同行颤抖?
蓝桥杯
YuTaoShao2 天前
【LeetCode 每日一题】1382. 将二叉搜索树变平衡——中序遍历 - 数组 - 平衡 BST
算法·leetcode·深度优先