蓝桥杯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;
}
相关推荐
考试宝5 小时前
国家宠物美容师职业技能等级评价(高级)理论考试题
经验分享·笔记·职场和发展·学习方法·业界资讯·宠物
面试鸭6 小时前
离谱!买个人信息买到网安公司头上???
java·开发语言·职场和发展
测试19988 小时前
2024软件测试面试热点问题
自动化测试·软件测试·python·测试工具·面试·职场和发展·压力测试
程序员勋勋11 小时前
【自动化测试】如何在jenkins中搭建allure
职场和发展·jenkins·测试覆盖率
咕咕吖11 小时前
对称二叉树(力扣101)
算法·leetcode·职场和发展
sszmvb123412 小时前
测试开发 | 电商业务性能测试: Jmeter 参数化功能实现注册登录的数据驱动
jmeter·面试·职场和发展
测试杂货铺12 小时前
外包干了2年,快要废了。。
自动化测试·软件测试·python·功能测试·测试工具·面试·职场和发展
测试界萧萧14 小时前
外包干了4年,技术退步太明显了。。。。。
自动化测试·软件测试·功能测试·程序人生·面试·职场和发展
小码哥说测试14 小时前
接口测试用例设计的关键步骤与技巧解析!
自动化测试·测试工具·jmeter·职场和发展·测试用例·接口测试·postman
linsa_pursuer15 小时前
快乐数算法
算法·leetcode·职场和发展