蓝桥杯2013年-带分数(暴力全排列check方案数)

题目描述

100 可以表示为带分数的形式:100 = 3 + 69258 / 714。

还可以表示为:100 = 82 + 3546 / 197。

注意特征:带分数中,数字1~9分别出现且只出现一次(不包含0)。

类似这样的带分数,100 有 11 种表示法。

思路

1~9的全排列大概为3e5,然后分割方案数为36种(C29),复杂度大概为1e7,能接受。

所以我们可以直接用next_permutation暴力枚举1~9的所有全排列,然后分割成三个数,符合则加上即可。

代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int a[10]={1,2,3,4,5,6,7,8,9};
int ned;
int get(){
    int x=0,y=0,z=0;
    int res=0;
    for(int i=0;i<7;i++){//第一个数所占的位数
        x=x*10+a[i];
        y=0;
        for(int j=i+1;j<8;j++){//第二个数所占的位数
            y=y*10+a[j];
            z=0;
            for(int k=j+1;k<9;k++){
                z=z*10+a[k];
            }
            if(y%z==0&&x+y/z==ned)res++;
            
        }
    }
    return res;
}
int main(){
    cin>>ned;
    int ans=0;
    do{
        ans+=get();
    }while(next_permutation(a,a+9));
    cout<<ans;
}
相关推荐
qq_459234423 天前
【题库】| 商用密码应用安全性评估从业人员考核题库(四十)
职场和发展·密码学·学习方法·考核·商用密码·商用密码应用安全性评估·密评
敲敲了个代码3 天前
[特殊字符] 空数组的迷惑行为:为什么 every 为真,some 为假?
前端·javascript·react.js·面试·职场和发展
诚思报告YH3 天前
视频面试软件市场洞察:2026 - 2032年复合年均增长率(CAGR)为10.3%
面试·职场和发展
重生之后端学习3 天前
74. 搜索二维矩阵
开发语言·数据结构·算法·职场和发展·深度优先
tyb3333333 天前
leetcode:吃苹果和队列
算法·leetcode·职场和发展
Pitiless-invader3 天前
MySQL 相关知识及面试问题汇总
面试·职场和发展
重生之后端学习3 天前
35. 搜索插入位置
java·数据结构·算法·leetcode·职场和发展·深度优先
逆境不可逃4 天前
【从零入门23种设计模式08】结构型之组合模式(含电商业务场景)
线性代数·算法·设计模式·职场和发展·矩阵·组合模式
筱昕~呀4 天前
冲刺蓝桥杯-DFS板块(第二天)
算法·蓝桥杯·深度优先
zheshiyangyang4 天前
前端面试基础知识整理【Day-10】
前端·面试·职场和发展