题目
JAVA11 求最小公倍数
分析:
代码:
//辗转相除法
public static int getCD(int m,int n){
if(m<n){//保持m代表的数 大。
int temp=n;
n=m;
m=temp;
}
while(n!=0){
int temp=n;
n=m%n;
m=temp;
}
System.out.println(m);
return m;
}
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner console = new Scanner(System.in);
int m = console.nextInt();
int n = console.nextInt();
int result = getCM(m, n);
System.out.println(result);
}
public static int getCM(int m, int n) {
return (m*n/getCD(m,n));
}
public static int getCD(int m, int n) {
if (m < n) { //保持m代表的数 大。
int temp = n;
n = m;
m = temp;
}
while (n != 0) {
int temp = n;
n = m % n;
m = temp;
}
//System.out.println(m);
return m;
}
}
大佬代码:
import java.util.*;
public class Main {
public static void main(String[] args) {
//标准输入
Scanner console = new Scanner(System.in);
int m = console.nextInt();
int n = console.nextInt();
//计算最小公倍数
int result = getCM(m, n);
//输出结果
System.out.println(result);
}
//计算最小公倍数
public static int getCM(int m, int n){
//计算m、n中较大者
int max=Math.max(m,n);
//从max到m*n之间找最小公倍数
for(int i=max;i<=m*n;i++){
//如果既能被m整除又能被n整除,说明是最小公倍数,直接返回
if(i%m==0&&i%n==0){
return i;
}
}
return -1;
}
}
int a = m;
int b = n;
//4 8 12 16 20
//6 12 18
while (true) {
if (m == n) {
break;
} else {
if (m < n) {
m += a;
} else {
n += b;
}
}
}
JAVA12 小球走过路程计算
分析:
代码:
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner=new Scanner(System.in);
float h=scanner.nextFloat();
int n =scanner.nextInt();
double sum=h;
for(int i=1;i<=n;i++){
h/=2;
if(i!=n){
sum+=2*h;
}
}
System.out.println(String.format("%.3f", h)+" "+String.format("%.3f", sum));
}
}