前三位,后三位(对数的整数小数,快速幂)

LINK
You are given two integers: n and k, your task is to find the most significant three digits, and least significant three digits of nk.

Input
Input starts with an integer T (≤ 1000), denoting the number of test cases.

Each case starts with a line containing two integers: n (2 ≤ n < 231) and k (1 ≤ k ≤ 107).

Output
For each case, print the case number and the three leading digits (most significant) and three trailing digits (least significant). You can assume that the input is given such that nk contains at least six digits.

Sample Input
5
123456 1
123456 2
2 31
2 32
29 8751919
Sample Output
Case 1: 123 456
Case 2: 152 936
Case 3: 214 648
Case 4: 429 296
Case 5: 665 669
题意:有n组数据,每组有m,k,求出m的k次方的前三位数和后三位数
分析:
前三位:任意的数都可以写成10^x的形式 y=10^x log(10)y=x
结合题意:nk=10y 两边取对数 log(10)n^k=klog(10)n=y
如果n^k%10不等于0,则y就是浮点数,其中整数部分是10的多少次方,
小数部分是具体的数值,也就是科学计数法的形式。
本题求的是小数的前三位,设a是y的整数部分,b是y的小数部分;
0<y<1, 1<10^y<10,所以求前三次就
100;
后三位:快速幂,记住模板,方法详见:快速幂


AC代码:

#include<stdio.h>
#include<math.h>
int main()
{
	long long t,g,n,k,min,ans;
	scanf("%lld",&t);
	g=1;
	while(t--)
	{
		ans=1;
		scanf("%lld %lld",&n,&k);
		double y=k*log10(n);
		int min=y,p;
		p=pow(10,y-min)*100;
		while(k)
		{
			if(k%2!=0)
			ans=ans*n%1000;
			n=n*n%1000;	
			k/=2;	
		}
		printf("Case %lld: %03d %lld\n",g++,p,ans);
		//printf("%d ",pow(10,y-min)*100);这样写不行,输出结果不对)
	}
} 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
任务描述 古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,用户输入一个月份数,计算并在一行内输出该月的兔子总对数以及前一个月与该月兔子数量的比值(计算并观察一下这个比值的数值是多少),比值结果保留小数点后3位,数字间用空格分隔。 输入格式‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬ 一个大于2的正整数‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬ 输出格式‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬ 在一行内输出两个数,数之间用空格隔开。第一个是整数,表示本月的兔子的对数,第二个是浮点数(严格保留小数点后三位),表示前一个月兔子数与本月兔子数的比值。 示例‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬ 输入:5 输出:5 0.600写出代码
06-07
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值