判断完全数 C++实现

编写函数perfect_num(n),判断n是否为完全数

(完全数是指一个数除了自身的所有因子之和恰好等于本身)

例如:
28的因子有1,2,4,7,14,28,
除去28其余5个数之和为28,
所以28为完全数

C++实现如下:

#include <iostream>

using namespace std;

//声明一个返回布尔类型的函数
bool perfect_num(int x);

int main() {
    //m,n起始数字;x当前检验的整数
    int m, n, x;
    cout << "input the range m, n: " << endl;
    cin >> m >> n;
    //从m到n依此筛选
    for (x = m; x <= n; ++x) {
        //使用函数,检查当前x是否符合条件
        if (perfect_num(x)) {
            cout << x << " ";
        }
    }
    return 0;
}

bool perfect_num(int x) {
    //初始化flag
    bool flag = false;
    //初始化所有因子之和
    int sum = 0, i;
    //遍历从1到x的所有整数
    for (i = 1; i < x; ++i) {
        //判断是否为因子
        if (x % i == 0) {
            sum += i;
        }
    }
    //更新flag
    flag = (sum == x);
    return flag;
}

试题总结:

①特别简单的语句没有必要写成函数;
②灵活运用sum,反思:不使用数组储存所有因子的好处;
③函数的基础运用一定要熟练!

  • 4
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++中,判断一个图是否为另一个图的完全子图涉及到图的遍历和比较。下面是一个简化的概述步骤: ### 完全子图的概念 一个图 G 的子图 H 被称为完全子图当它包含 G 中的所有顶点,并且连接每个对的边在 G 中也存在。 ### C++ 实现步骤 为了判断一个图是否是另一个图的完全子图,可以按照以下步骤编写程序: #### 步骤 1: 图的表示 通常我们用邻接矩阵或邻接表来表示图。 ```cpp // 使用邻接矩阵表示图 bool isCompleteSubgraph(int mainGraph[][V], int subGraph[][V], int V) { ``` #### 步骤 2: 遍历主图并检查所有顶点是否存在子图中 接下来我们需要检查主图中的每一对顶点是否有边存在于子图中。 ```cpp for (int i = 0; i < V; i++) { for (int j = i + 1; j < V; j++) { // 检查主图中(i,j)之间的边是否在子图中也存在 if ((mainGraph[i][j] && !subGraph[i][j])) { return false; } } } ``` 这里假设 `mainGraph` 和 `subGraph` 分别代表主图和子图的邻接矩阵。如果在遍历过程中发现任何一对在主图中相邻但在子图中却不存在,则可以直接返回 `false` 表示该子图不是主图的完全子图。 #### 步骤 3: 确保所有顶点都在子图中 最后,需要确保子图包含了主图的所有顶点。 ```cpp if (!isAllVerticesPresent(mainGraph, V, subGraph)) { return false; } ``` 其中 `isAllVerticesPresent()` 函数用于检查所有主图的顶点是否都在子图中。这可以通过遍历主图的每个顶点并在子图中查找对应的顶点来完成。 #### 完整函数实现 完整版本的函数可能如下所示: ```cpp #include <iostream> using namespace std; bool isCompleteSubgraph(int mainGraph[][V], int subGraph[][V], int V) { for (int i = 0; i < V; i++) { for (int j = i + 1; j < V; j++) { if ((mainGraph[i][j] && !subGraph[i][j])) { return false; } } } bool allVerticesPresent = true; for (int i = 0; i < V; i++) { bool found = false; for (int j = 0; j < V; j++) { if (mainGraph[i][j]) { found = true; break; } } if (!found) { allVerticesPresent = false; break; } } return allVerticesPresent; } // 示例用法 int main() { int V = 4; // 假设图有4个顶点 int mainGraph[V][V] = {{0, 1, 1, 0}, {1, 0, 1, 1}, {1, 1, 0, 1}, {0, 1, 1, 0}}; int subGraph[V][V] = {{0, 1, 0}, {1, 0, 1}, {0, 1, 0}}; cout << "Is complete subgraph? " << isCompleteSubgraph(mainGraph, subGraph, V); return 0; } ``` ### 相关问题: 1. **如何优化这个算法以减少不必要的计算?** 可以通过提前检测子图是否包含某个特定顶点来减少不必要的遍历次数。例如,在检查两个顶点之间是否连通之前,先确认它们都在子图中。 2. **在实际应用中遇到的常见错误是什么?** 常见错误包括误操作二维数组、边界条件处理不当以及数据类型混淆等。确保输入和输出的维度一致是非常重要的。 3. **此算法适用于无向图还是有向图?** 这种基于邻接矩阵的方法适用于无向图。对于有向图,通常需要使用邻接列表或其他更适合表示有向边的数据结构。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值