设一个数 A 的最低 D 位形成的数是 ad。如果把 ad 截下来移到 A 的最高位前面,就形成了一个新的数 B。B 是 A 的多少倍?例如将 12345 的最低 2 位 45 截下来放到 123 的前面,就得到 45123,它约是 12345 的 3.66 倍。
输入格式:
输入在一行中给出一个正整数 A(≤109)和要截取的位数 D。题目保证 D 不超过 A 的总位数。
输出格式:
计算 B 是 A 的多少倍,输出小数点后 2 位。
输入样例 1:
12345 2
输出样例 1:
3.66
输入样例 2:
12345 5
输出样例 2:
1.00
代码实现:
import java.io.*;
/**
* @author yx
* @date 2022-07-27 19:08
*/
public class Main {
static PrintWriter out=new PrintWriter(System.out);
static BufferedReader ins=new BufferedReader(new InputStreamReader(System.in));
static StreamTokenizer in=new StreamTokenizer(ins);
public static void main(String[] args) throws IOException {
in.nextToken();
int A=(int) in.nval;
in.nextToken();
int D=(int) in.nval;
String s_A=A+"";
String a1=s_A.substring(0,s_A.length()-D);
String a2=s_A.substring(s_A.length()-D,s_A.length());
int a=(Integer.parseInt(a2+a1));
System.out.printf("%.2f",a*1.0/A);
}
}
标签:JAVA,String,int,样例,多少倍,static,1101,new,12345 From: https://blog.51cto.com/u_15754851/5763820