第12周 报告1 --- 2-1000内的完数

任务1:(课本p86第20题)一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3,再如8的因子和是7(即1+2+4),8不是完数。编程找出1000以内的所有完数。

本文先给出我做的程序,后面加上对同学们做法的点评。

【第一部分 我的报告】
实验目的:学会使用循环控制语句解决实际问题,并强化注重效率的观念
实验内容:用循环控制语句编写程序,完成表达式的计算

/* 程序头部注释开始
 * 程序的版权和版本声明部分
 * Copyright (c) 2011, 烟台大学计算机学院
 * All rights reserved.
 * 文件名称:completeNumber.cpp
 * 作    者:贺利坚
 * 完成日期: 2011 年 11 月 15 日
 * 版 本 号: v1.0
 * 对任务及求解方法的描述部分
 * 输入描述:无
 * 问题描述:一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3,再如8的因子和是7(即1+2+4),8不是完数。编程找出1000以内的所有完数。
 * 程序输出:1000以内的所有完数
 * 问题分析:首先从2到1000构造循环控制变量为i的外层循环。每次循环中,利用内嵌的循环逐个地求出i的因子,并累加起来(为提高效率,可能考虑因子的对称性,即j为小于sqrt(i)的因子,则一定有i/j也是因子),若累加和与i相等,则i是完全数,输出。然后继续循环,考察i+1……
 * 算法设计:……
 * 程序头部的注释结束
 */

#include <iostream>
#include<Cmath>
using namespace std;
int main( )
{
  int i,s,j;
  cout<<"2-1000之间的完数有:";
  for(i=2;i<=1000;i++)
  {
    s=1; //1是任何数的因子,所以不再s=1,也使下一句可以从2开始
    for(j=2;j<sqrt(i);j++)   //正因为j从2开始,才有胆量让j到sqrt(i)
      if(i%j==0) s+=(j+i/j);  //加上j的同时,和j对称的那个因子(i/j)也被累加了
                             //思考:如果j允许从1开始,上式会将i本身也累加上去
    if(i==s) cout<<i<<"  ";
  }
  cout<<endl;
  return 0;
}

运行结果:

经验积累:
1. 学会了循环嵌套
2. 人聪明些,可以让计算机少做些工作,从而提高效率。一将无能,累死三军。当程序猿的,要做个好将军。

【第二部分 同学们做法的点评】
随着同学们的程序越编越大,我没有精力细看每一个程序。
映像中没有一个同学做到了for(j=2;j<sqrt(i);j++) ,使j的取值只到sqrt(i)。
大家普遍写的程序如下,考虑了效率,但不够彻底。效率问题,还得长期修炼。

  for(i=2;i<=1000;i++)
  {
    s=1;
    for(j=2;j<=i/2;j++)
      if(i%j==0) s+=j;
    if(i==s) cout<<i<<"  ";
  }

我在for循环之外写了cout<<"2-1000之间的完数有:";如图的输出比较舒服。而有些同学在循环内写了cout<<i;之外,还用字符串输出了其他文字,使用户体验不好了。
这个题是典型的用计数型for循环的,用其他循环可以玩一玩,但做这题时,优先用for。

时间: 2024-09-22 13:11:34

第12周 报告1 --- 2-1000内的完数的相关文章

求1000以内的完数。并输出。

问题描述 publicclassWanShu{publicstaticvoidmain(String[]args){inti,j,h=0;for(i=1;i<=1000;i++){for(j=1,h=0;j<=i/2;j++){if(i%j==0)h=h+j;}if(h==i)System.out.print("1000以内的完数");System.out.println();System.out.print(i);}}}用java语言编的不知哪错了.运行结果是输出了1~1

第12周报告2-2 大奖赛计分程序

任务2-1:为大奖赛编制一个计分程序,成绩在0-10之间,输入错误时要能马上重新输入.评委人数在程序中的修改要尽可能方便. 任务2-2:在任务2-1的基础上,输出当前选手的最后得分后,提示"按任意键计算下一位选手的成绩,退出请选择N:"如果输入的不是N或n,可以为下一位选手计算成绩.运行结果如图所示,将此任务写入报告,体会:如果一个大任务难于直接完成,可以先完成核心任务,再逐渐完善. 第一部分是我的解答,第二部分总结同学们的做法. [第一部分 我的报告] 实验目的:学会使用循环控制语句

第12周报告3 --- 计算存款利息

任务3:输入存款金额并选择存款种类,计算出利息(不计利息税).如果是活期存款,需要补充输入天数.利息=金额×年利率×存期(单位:年,活期一年按360天计).要求使用switch语句,根据选择的存款种类,确定利率和存期后计算.利率使用2011年7月7日公布的最新年利率:活期  0.50%,3个月  3.10%,6个月 3.30%,一年 3.50%,二年 4.40%,三年 5.00%,五年 5.50%. 完整的利息计算器可以参考http://www.bankrate.com.cn/tools/sav

2013级C++第12周项目——函数应用

课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759 [项目1-当年第几天] 定义一个函数,其参数为年.月.日的值,返回这一天为该年的第几天.要求在main函数中输入年月日,然后调用这个函数求值,并在main函数中输出结果. [项目2-太乐了]先听故事,再编程序. 故事是这样的:话说sin和cos是一对夫妇.一天,sin去听相声了,cos在家.过了一会,有人敲门,cos开门一看,是一个不认识的多项式函数.cos问:你是谁啊?

2013-C++第12周项目参考解答链接集

课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759 [项目1-当年第几天] 定义一个函数,其参数为年.月.日的值,返回这一天为该年的第几天.要求在main函数中输入年月日,然后调用这个函数求值,并在main函数中输出结果. 参考解答在:http://blog.csdn.net/sxhelijian/article/details/16330759 [项目2-太乐了]先听故事,再编程序. 故事是这样的:话说sin和cos是一

IPO初审排队企业连续12周零申报

证监会网站最新数据显示,上周朿家公司新股发衿IPO)申请终止审查,并无新增排队企业进入初审名单,初审排队企业已连绿2周零申报〿/p> 证监会公布的企业申报信息表显示,上周南京斯迈柯特种金属装备股份有限公叿简称"斯迈柯‿被终止审查,保荐商为东方证券,终止时间为2朿6日,之前的审核状态为"已通过发审会",原本计划在创业板上市〿/p> 据悉,斯迈柯亿011广2月过会,此前拟发衿465万股,该公司为民营股份制高新技术企业,专业从事有色金属.不锈钢及其复合材料压力容器设计与

php找出指定范围内回文数且平方根也是回文数的方法

这篇文章主要介绍了php找出指定范围内回文数且平方根也是回文数的方法,实例分析了php判断回文的技巧,具有一定参考借鉴价值,需要的朋友可以参考下     本文实例讲述了php找出指定范围内回文数且平方根也是回文数的方法.分享给大家供大家参考.具体如下: 一.要求: 给出两个数值X和Y,统计在这个区间里的回文数,并且要求它们的平方根也是回文数.其中 1<= x <= y < 10 14 二.解决方法: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17

2014秋C++第10周项目5参考-输出完数

课程主页在http://blog.csdn.net/sxhelijian/article/details/39152703,课程资源在云学堂"贺老师课堂"同步展示,使用的帐号请到课程主页中查看.   [项目5:输出完数](课本p86第20题)一个数如果恰好等于它的因子之和,这个数就称为"完数".例如6=1+2+3,再如8的因子和是7(即1+2+4),8不是完数.编程找出1000以内的所有完数.提示:首先从2到1000构造循环控制变量为i的外层循环.每次循环中,利用内

C++第10周项目4参考——完数

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565 [项目4:输出完数](课本p86第20题)一个数如果恰好等于它的因子之和,这个数就称为"完数".例如6=1+2+3,再如8的因子和是7(即1+2+4),8不是完数.编程找出1000以内的所有完数.提示:首先从2到1000构造循环控制变量为i的外层循环.每次循环中,利用内嵌的循环逐个地求出i的因子,并累加起来(为提高效率,可能的因子从1到i/2),如果因子和等于i