实验三:分别用for、while和do-while循环语句以及递归方法计算n!,并输出算式
一、用for循环计算n!
package for_package;
import java.util.*;//导入含有输入类的包
public class for_class {
/**
* @param args
*/
public static void main(String[] args) {//void代表不会有返回值,参数也可以不用写
// TODO Auto-generated method stub
int i;
int fact=1;
int n;
Scanner in=new Scanner(System.in);//使用Scanner类定义对象
System.out.println("请输入n:");
n=in.nextInt();
for(i=1;i<=n;i++)
{
fact=fact*i;
}
for(i=1;i<=n;i++)
if(i<n)//用来控制最后一个数后面不加*
System.out.print(i+"*");//记得加+
else
System.out.print(i);
System.out.print("="+fact);
}
}

二、用while循环计算n!
package while_package;
import java.util.*;//导入含有输入类的包
public class while_class {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
int i=1;
int fact=1;
int n;
Scanner in=new Scanner(System.in);//使用Scanner类定义对象
System.out.println("请输入n:");
n=in.nextInt();
while(i<=n)
{
fact=fact*i;
i=i+1;
}
for(i=1;i<=n;i++)
if(i<n)//用来控制最后一个数后面不加*
System.out.print(i+"*");//记得加+
else
System.out.print(i);
System.out.print("="+fact);
}
}

三、用do-while循环计算n!
package do_while_package;
import java.util.*;//导入含有输入类的包
public class do_while_class {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
int i=1;
int fact=1;
int n;
Scanner in=new Scanner(System.in);//使用Scanner类定义对象
System.out.println("请输入n:");
n=in.nextInt();
do
{
fact=fact*i;
i=i+1;
}while(i<=n);//do-while语句后面有分号
for(i=1;i<=n;i++)
if(i<n)//用来控制最后一个数后面不加*
System.out.print(i+"*");//记得加+
else
System.out.print(i);
System.out.print("="+fact);
}
}

四、用递归方法计算n!
package digui_package;
import java.util.*;//导入含有输入类的包
public class digui_class {
public static void main(String[] args) {
int i;
int fact=1;
int n;
Scanner in=new Scanner(System.in);//使用Scanner类定义对象
System.out.println("请输入n:");
n=in.nextInt();
fact=digui(n); //不能对类型 digui_class 中的非静态方法 digui(int)进行静态引用,即
for(i=1;i<=n;i++)
if(i<n)//用来控制最后一个数后面不加*
System.out.print(i+"*");//记得加+
else
System.out.print(i);
System.out.print("="+fact);
}
public static int digui(int n)
{
if(n==0||n==1)
return 1;
return n*digui(n-1);
}
}

五、心得总结与疑惑
1、Java中想要从键盘上输入一个数时,要导入含有输入类的包,即import java.util.*;,在主函数中,使用Scanner类定义对象,即Scanner in=new Scanner(System.in);n=in.nextInt();即可。
2、public static void main(String[] args) void代表不会有返回值,参数也可以不用写。
3、do-while语句后面有分号。
4、格式控制输出算式时,用if语句来控制最后一个数后面不加*。
5、递归调用时,要有一个边界条件,即至少有一条初始定义是非递归的,另外还要有一个递推通式。
实验三:分别用for、while和do-while循环语句以及递归方法计算n!,并输出算式的更多相关文章
- 实验三:分别用for,while和do-while循环语句以及递归方法计算n!,并输出算式
1.for循环语句计算n! 2.while循环语句计算n! 3.do-while语句计算n! 4.递归方法计算n! 5.心得:在此次实验中不知道如何从键盘进行输入,通过百度后找到一种容易理解的输入方法 ...
- 实验二 Java基础(数据/表达式、判定/循环语句)
实验二 (一)实验内容 编写简单的计算器,完成加减乘除模运算. 要求从键盘输入两个数,使用判定语句选择一种操作,计算结果后输出,然后使用判定和循环语句选择继续计算还是退出. 编写测试代码,测试验证. ...
- C语言基础三(敲打键盘、寻找资料,循环语句)
有人在学C语言或者其他语言的时候,大家都会说逻辑思维的硬道理,认为没有逻辑思维的人走不远,那么小编这里借助简单的if...else... 英文解释if(如果),else(否则) ----------- ...
- 写给.NET开发者的Python教程(三):运算符、条件判断和循环语句
本节会介绍Python中运算符的用法,以及条件判断和循环语句的使用方法. 运算符 运算符包括算术运算符.赋值运算符.比较运算符.逻辑运算符等内容,大部分用法和C#基本一致,下面我们来看一下: 算数运算 ...
- FPGA与simulink联合实时环路系列——实验三 按键key
实验三 按键key 实验内容 在FPGA的实验中,经常涉及到按键的使用,按键是必不可少的人机交互的器件之一,在这些实验中,有时将按键的键值读取显示到数码管.LCD或者是通过串口传送到PC的串口助手上进 ...
- Java实验三
20145113 20145102实验三 实验步骤 编码标准 编程标准包含:具有说明性的名字.清晰的表达式.直截了当的控制流.可读的代码和注释,以及在追求这些内容时一致地使用某些规则和惯用法的重要性 ...
- Verilog HDL那些事_建模篇笔记(实验三:按键消抖)
实验三:按键消抖 首先将按键消抖功能分成了两个模块,电平检查模块和10ms延迟模块.电平检测模块用来检测按键信号的变化(是否被按下),10ms延迟模块用来稳定电平检查模块的输入,进而稳定按键信号,防止 ...
- 20145229&20145316 《信息安全系统设计基础》实验三 实时系统的移植
实验封面 实验内容 1.安装ADS(安装文件在00-ads1.2目录下,破解方法00-ads1.2\Crack目录下) 2.安装GIVEIO驱动(安装文件在01-GIVEIO目录下) 3.把整个GIV ...
- 20145301&20145321&20145335实验三
20145301&20145321&20145335实验三 这次实验我的组员为:20145301赵嘉鑫.20145321曾子誉.20145335郝昊 实验内容详见:实验三
随机推荐
- NSNotificationCenter 注意
成对出现 意思很简单,NSNotificationCenter消息的接受线程是基于发送消息的线程的.也就是同步的,因此,有时候,你发送的消息可能不在主线程,而大家都知道操作UI必须在主线程,不然会出现 ...
- 如何通过cmd命令进入到某个硬盘的文件夹
1.使用快捷键win+R打开运行窗口,并输入cmd回车 2.进入到某个磁盘:在命令提示符中输入d:(代表的的是进入D盘的根目录)并回车 3.接着在cmd中输入dir(dir是directory目录的简 ...
- 2018.10.14 bzoj1915: 奶牛的跳格子游戏(单调队列优化dp)
传送门 NOIP练习题. f[i]f[i]f[i]表示去的时候选了iii且回来的时候第一步走的是i−1i-1i−1的最优值. 显然f[i]=maxf[i]=maxf[i]=max{f[j]−sum[j ...
- 2018.07.23 洛谷P4097 [HEOI2013]Segment(李超线段树)
传送门 给出一个二维平面,给出若干根线段,求出x" role="presentation" style="position: relative;"&g ...
- linux week3
2.如何快速的回到 上⼀一次所在的位置 cd An argument of - is equivalent to $OLDPWD. cd - #cd $OLDPWD cd - #快速的回到 上 ...
- linux下mysql命令大全
1.linux下启动mysql的命令: mysqladmin start /ect/init.d/mysql start (前面为mysql的安装路径) 2.linux下重启mysql的命令: mys ...
- HDU 2393 Higher Math (判断直角三角形)
题意:给定三个边,判断是不是直角三角形. 析:水题,勾股定理... 代码如下: #include <iostream> #include <cstdio> #include & ...
- Oracle零碎总结:结构-工具-创建语句
前言:Oracle内部的存储及管理结构是1.数据库系统:2.数据库实例:3.表空间,系统用户system,普通用户:表,视图,触发器,存储过程等: 一.Oracle数据库系统和数据库实例的对应关系是一 ...
- 完美解决VC++6.0与Visio/office不兼容问题!!!
话说电脑上如果装有VC++6.0编程软件和Visio或office办公软件,那么经常编程的人就会遇到下面的问题:VC打不开文件和工程,总是提示读取内存错误,点“确定”后vc自动关闭,但vc却能新建文件 ...
- Hdu1978 How many ways 2017-01-18 14:32 40人阅读 评论(0) 收藏
How many ways Time Limit : 3000/1000ms (Java/Other) Memory Limit : 32768/32768K (Java/Other) Total ...