JAVA每日随手练【方法的创建与调用】
1.求N的阶乘
功能:输入一个数N,并求N的阶乘
代码:
//求N的阶乘
import java.util.Scanner;
public class test1 {
public static void main(String[] args) {
System.out.print("请给出计算阶乘的数:");
Scanner sc = new Scanner(System.in); //用Scanner接收值,再用循环遍历
int m = sc.nextInt();
int ret=fac(m);
System.out.println(m+"的阶乘为:"+ret);
sc.close();
}
public static int fac(int m){
int k = 1;
for (int i=1;i<=m;i++){
k *= i; //k=k*i
}
System.out.println("计算n的阶乘中......");
return k;
}
}
运行结果:
2.求N的阶乘和
功能:给出一个数N,求1!+2!+……N!
代码:
//求1!+2!+3!+4!+........+n!的和
//求N的阶乘和
import java.util.Scanner;
public class test2 {
public static void main(String[] args) {
System.out.print("请给出计算阶乘和的数:");
Scanner sc = new Scanner(System.in); //用Scanner接收值,再用循环遍历
int n = sc.nextInt();
int sum =0;
for (int i=1;i<=n;i++){
sum += fac(i); //sum=sum+fac(i)
}
System.out.println(n+"的阶乘和为:"+sum);
sc.close();
}
public static int fac(int n){
int k = 1;
for (int i=1;i<=n;i++){
k *= i; //k=k*i
}
System.out.println("计算"+n+"的阶乘:"+n+"!="+k);
return k;
}
}
运行结果:
3.找出出现一次的数字
要求:有一组数据,只有一个数字是出现一次,其他是两次,请找出这个数字。
//有一组数据,只有一个数字是出现一次,其他是两次,请找出这个数字。
/**
* 找出只出现一次的数字
* 有一组数据,只有一个数字是出现一次,其他是两次,请找出这个数字。
* 如1 3 2 4 2 1 4 只出现一次的数字就是3
*/
public class test3 {
public static void main(String[] args) {
int[] arr = {1, 1, 2, 2, 3, 3, 4, 4, 5,7};
frequency(arr);
}
public static void frequency(int[] a) {
for (int i = 0; i < a.length; i++) {
int count = 0; //判断出现次数,出现2次的则为重复数字,仅一次的为所需数字
for (int j = 0; j < a.length; j++) {
if (a[i] == a[j]) count++;
}
if (count == 1)
System.out.println("只出现一次的数字是:" + a[i]);//只出现一次则输出该数据
}
}
}
运行结果: