栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

【PAT乙级】1096 大美数 (15 分) DFS回溯解法

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

【PAT乙级】1096 大美数 (15 分) DFS回溯解法

题目

1096 大美数 (15 分)
若正整数 N 可以整除它的 4 个不同正因数之和,则称这样的正整数为“大美数”。本题就要求你判断任一给定的正整数是否是“大美数”。

输入格式:
输入在第一行中给出正整数 K(≤10),随后一行给出 K 个待检测的、不超过 1e4 的正整数。

输出格式:
对每个需要检测的数字,如果它是大美数就在一行中输出 Yes,否则输出 No。

分析

先求出N所有因数
在所有因数里,4个一组枚举所有情况
可以四重for循环,也可以dfs

注意事项

a整除b是b÷a

代码(C++)
#include
using namespace std;
// 关于为什么要开200,因为一个数的因数个数上界不会超过2乘根号n
// 数字最大是1e4,开根后乘2就是200
const int N = 200;
int n,num;
int len;
int a[N];
bool used[N];
bool dfs(int step,int sum) {
    if(step==4) return sum%num==0;
    for(int i = 0;i>n;
    while(n--) {
        cin>>num;
        for(int i = 1;i<=num;i++) {
            if(num%i==0) a[len++] = i;
        }
        if(len<4) {
            cout<<"No"<
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/714590.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号