1101 B是A的多少倍
设一个数 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
代码长度限制 16 KB
时间限制 200 ms
内存限制 64 MB
/*
1101 B是A的多少倍
https://pintia.cn/problem-sets/994805260223102976/exam/problems/1478634052026146816
*/
#include <iostream>
using namespace std;
int YiDong(int num,int needToMove)
{
int arr[100],length=0,sum=0;
while(num!=0)
{
arr[length++]=num%10;
num/=10;
}
for(int i=needToMove-1;i>=0;i--)
sum=sum*10+arr[i];
for(int i=length-1;i>=needToMove;i--)
sum=sum*10+arr[i];
return sum;
}
int main()
{
int num,needToMove;
cin>>num>>needToMove;
int yidong=YiDong(num, needToMove);
printf("%.2lf",yidong*1.0/num);
}