1、1不是完全数,所以printf("1=1");没有必要打,并且打印完之后没有\n换行 2、m没有初始化,需要在for(i=1;i<j;i++)之前初始化m=0 3、最后的printf("\n");需要放在if(m==j)判断里面,不然每一次for(j=2;j<=1000;j++)循环都会打印一个换行符,前面输出的结果就没了。 修改后的代码如下,楼...
编写控制台[1]应用程序,求1000之内的所有“完数”。所谓“完数”是指一个数恰好等于它的所有因子之和。例如,6是完数,因为6=1+2+3。
31*31=961 32*32=1024
using System;using System.Collections;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;namespace ConsoleApplication1 { public class Program { static void Main(string[] args){ for (int i = 1; i <= 1000; i++)isPerfectNum(i);} ///...
例如,6的正除数有1、2、3,它们的和正好等于6,所以6是一个完美数。视频中首先介绍了完美数的定义,然后通过一个具体的编程题目,详细讲解了如何使用循环遍历1到1000范围内的所有数,对每个数求出它的所有正除数,并将这些除数累加求和。如果某个数的除数之和等于它本身,那么这个数就是一个完美数。视频中还提到了...
Dim i As Integer Dim j As Integer Dim s As Integer Dim k As Integer '循环检查0-1000 For i = 1 To UpperBound s = 0 '判断完数 For j = 1 To i - 1 If i Mod j = 0 Then s = s + j Next j If s = i Then Print i & "是完数\因子:"; '输出完数 '判断因子 ...
是,没错,就只有这3个
include<stdio.h> int main(){ int k=1,i,a;for(i=3;i<=1000;i++){ k=1;//这里少了这句 for(a=2;a
[nforninrange(1,1000)ifsum(kforkinrange(1,n)ifn%k==0)==n]另一方面这又是个数学题目。可以...
main(){ int i,j,k=1; for (i=2;i<=1000;i++) { k=1; //每次内循环开始都要重置k for (j=2;j