下载可编辑

.专业.整理.

学 院

XX学院

班 级

XX

学 号

XX

姓 名

XXX

摘要

我选择的是数学型综合作业:(A)求最大数;(B)高次方数的尾数。

主要内容:(A)求555555的约数中最大的三位数; (B)求13的13次方的最后三位数。

基本设计思路:(A)题目的设计思路是:因为要求的是三位数,就用555555从小到大依次除以100到999的所有数,并判断能否整除,最后一个可以整除555555的数即为所求。(B)题目的设计思路是:乘积的最后三位数只与乘数和被乘数的后三位数有关,因此用1乘以13,再除以1000并取余数,用余数乘以13,再除以1000并取余数,依次进行下去,累乘13个13后除以1000取得的余数即为所求。

在(A)题目中,我限定了除数的范围,减少了计算次数,省去了比较约数大小的步骤,使程序更加简洁。在(B)题目中我没有拿13累乘13次,而是取每一次乘13所得乘积的最后三位数依次乘13,大大减少了计算,简化了程序;取最后三位数我利用除以1000 取余数的方法,方便、快捷。两个题目中均使用FOR循环,程序书写简练明了。

我个人认为这两个题目我不编写得比较简洁,运算结果正确,很好地完成了题目要求。

目录

TOC \o "1-4" \h \z 1 摘要 3

1.1 设计题目 3

1.2 设计内容 3

1.3 开发工具 3

1.4 应用平台 3

2 详细设计 3

2.1 程序结构 3

2.2 主要功能 3

2.3 函数实现 3

2.4 开发日志 4

3 程序调试及运行 4

3.1 程序运行结果 4

3.2 程序使用说明 4

3.3 程序开发总结 4

4 附件(源程序) 4

1 摘要

1.1 设计题目

(A)求最大数;(B)高次方数的尾数

1.2 设计内容

(A)求555555的约数中最大的三位数; (B)求13的13次方的最后三位数

1.3 开发工具

Visual C++ 6.0和Win32。

1.4 应用平台

Windows XP 32位

2 详细设计

2.1 程序结构

(A)求最大数

c=0a<=999?

c=0

a<=999?

输出c

a++

结束

c=a

b=555555

a=100

开始

b%a==0?

(B)高次方数的尾数

j=1i<=13?输出j

j=1

i<=13?

输出j

i++

结束

j=j*13%1000

i=1

开始

2.2 主要功能

程序功能:(A)求555555的约数中最大的三位数; (B)求13的13次方的最后三位数。

原理和方法:

(A)题目的原理和方法:因为要求的是三位数,就用555555从小到大依次除以100到999的所有数,并判断能否整除,最后一个可以整除555555的数即为所求。循环语句采用for循环。

(B)题目的原理和方法:乘积的最后三位数只与乘数和被乘数的后三位数有关,因此用1乘以13,再除以1000并取余数,用余数乘以13,再除以1000并取余数,依次进行下去,累乘13个13后除以1000取得的余数即为所求。循环语句采用for循环。

2.3 函数实现

(A)求最大数

int a,b=555555,c; /*定义变量,赋初值*/
for(a=100;a<=999;a++) /*FOR循环*/
{
if(b%a==0) /*利用IF语句判断b是否可以被a整除*/
c=a; /*将555555的约数赋给c*/
}
printf("%d\n",c); /*输出c*/
(B)高次方数的尾数
int i,j=1; /*定义变量,赋初值*/
for(i=1;i<=13;i++) /*FOR循环*/
{
j=j*13%1000; /*将j乘以13的乘积的后三位数赋给j*/
}
printf("%d\n",j); /*输出j*/

2.4 开发日志

(A)选定这个题目后,我先分析此题用何种算法完成,确定了使用FOR循环并限定除数范围,然后画出程序框图,再一步步编写源代码。调试过程很顺利,只有一个地方忘加了“;”。运行程序后,结果非常满意。

(B)这个题目不难,但是也不简便,我想到只取三位数的方法,并使用FOR循环,然后画出程序框图,再一步步编写源代码。调试过程发现对其中一个变量的初值是1还是13有待解决,分析程序后发现应该用1,然后进一步调试,运行,直至结果正确。

3 程序调试及运行

3.1 程序运行结果

(A)求最大数

求得555555的