首页 > 编程语言 >算法速通-90题(1—完数难题)[含pyhton,java,c++]

算法速通-90题(1—完数难题)[含pyhton,java,c++]

时间:2024-09-27 19:21:28浏览次数:17  
标签:count java 速通 int sum list 整数 c++ main

题目:完数难题

  题目描述如下: 

      小明正在进行期末数学考试,现在他遇到了这样一个题:如果一个大于 1 的正整数的所有因子之和等于它的本身,则称这个数是完数

      比如 6,28 都是完数:6=1+2+3 ; 28=1+2+4+7+14。请判断两个正整数之间完数的个数。小明想请聪明的你帮帮他

   输入输出格式
   输入格式
   输入包含两个正整数 n1 和 n2 ,表示题目描述中的数据范围。
  正整数之间以空格间隔。
   输出格式
  针对输入,请打印出 n1 和 n2 之间(包括边界)存在的完数个数 

  • 1.下面是python的做法:

count = 0
n,m=map(int,input("").split())
for i in range(n,m+1):
    list = []
    for j in range(1,i):
        if i % j==0:
            list.append(j)
    if sum(list) == i :
        count+=1
print(count)

运行出来可以得到输入的2个数之间的数有多少个符合完整数要求的数

  1. 读取用户输入的两个整数n和m,使用map函数将输入的字符串转换为整数。
  2. 初始化一个名为count的变量,用于记录完全数的数量。
  3. 使用一个for循环遍历从n到m的所有整数。
  4. 对于每个整数i,初始化一个名为list的空列表,用于存储i的所有因子。
  5. 使用另一个for循环遍历从1到i-1的所有整数j,检查j是否是i的因子(即i能被j整除)。如果是,将j添加到list中。
  6. 如果list中所有元素的和等于i,说明i是一个完全数,将count加1。
  7. 循环结束后,输出count的值,即在n和m之间的完全数的数量

    2.下面是java的做法:

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();
        int m = scanner.nextInt();
        int count = 0;
        for (int i = n; i <= m; i++) {
            int sum = 0;
            for (int j = 1; j < i; j++) {
                if (i % j == 0) {
                    sum += j;
                }
            }
            if (sum == i) {
                count++;
            }
        }
        System.out.println(count);
    }
}

和上面的同理:运行出来可以得到输入的2个数之间的数有多少个符合完整数要求的数

  1. 导入Scanner类,用于从控制台读取用户输入。
  2. 定义一个名为Main的公共类,包含一个main方法,作为程序的入口点。
  3. 在main方法中,创建一个Scanner对象,用于读取用户输入的两个整数n和m。
  4. 初始化一个名为count的变量,用于记录完全数的数量。
  5. 使用一个for循环遍历从n到m的所有整数。
  6. 对于每个整数i,初始化一个名为sum的变量,用于存储i的所有因子之和。
  7. 使用另一个for循环遍历从1到i-1的所有整数j,检查j是否是i的因子(即i能被j整除)。如果是,将j添加到sum中。
  8. 如果sum等于i,说明i是一个完全数,将count加1。
  9. 循环结束后,输出count的值,即在n和m之间的完全数的数量。

                                3..下面是c++的做法:

#include <iostream>
#include <vector>

int main() {
    int count = 0;
    int n, m;
    std::cin >> n >> m;
    for (int i = n; i <= m; i++) {
        std::vector<int> factors;
        for (int j = 1; j < i; j++) {
            if (i % j == 0) {
                factors.push_back(j);
            }
        }
        int sum = 0;
        for (int factor : factors) {
            sum += factor;
        }
        if (sum == i) {
            count++;
        }
    }
    std::cout << count << std::endl;
    return 0;
}
  1.  C++代码首先包含了必要的头文件,然后定义了一个名为main的函数。
  2. main函数中,我们首先初始化计数器  count为0,然后从标准输入读取两个整数nm
  3. 接下来,我们使用一个循环遍历范围[n, m]内的每个整数i。对于每个整数i,我们创建一个名为factors的向量来存储它的因子。
  4. 然后,我们使用另一个循环遍历1到i-1之间的所有整数j,如果i可以被j整除,就将j添加到factors向量中。
  5. 接着,我们计算factors向量中所有元素的和,并将其与i进行比较。如果它们的和相等,说明i是一个完全数,我们将计数器count加1。
  6. 最后,我们将计数器的值输出到标准输出。

标签:count,java,速通,int,sum,list,整数,c++,main
From: https://blog.csdn.net/weixin_49600177/article/details/142593355

相关文章

  • 广州C++信奥老师解一本通题 1919:【02NOIP普及组】选数
    ​ 【题目描述】已知nn个整数x1,x2,……xn以及一个整数K(K<n)。从n个整数中任选K个整数相加,可分别得到一系列的和。例如当n=4, k=34个整数分别为3,7,12,193,7,12,19时,可得全部的组合与它们的和为:3+7+12=223+7+19=297+12+19=383+12+19=34现在,要求你计......
  • 事件【JavaScript】
    1.事件事件是用户或浏览器动作的表示,JavaScript中的一切交互都是通过事件来处理的。2. 事件冒泡(EventBubbling)事件冒泡是指事件从最具体的元素(即触发事件的元素)开始触发,然后逐级向上传播到较为不具体的元素(即该元素的父元素、祖先元素),直到到达最顶层的元素(通常是documen......
  • C++离线查询
    前言C++算法与数据结构打开打包代码的方法兼述单元测试概念及原理离线算法(offlinealgorithms),离线计算就是在计算开始前已知所有输入数据,输入数据不会产生变化,且在解决一个问题后就要立即得出结果的前提下进行的计算。通俗的说:离线查询:问完所有问题后,依次回答。可......