首页 > 其他 > 详细

NYIST 46 最少乘法次数

时间:2014-11-06 16:23:55      阅读:120      评论:0      收藏:0      [点我收藏+]

最少乘法次数

时间限制:1000 ms  |  内存限制:65535 KB
难度:3
 
描述

给你一个非零整数,让你求这个数的n次方,每次相乘的结果可以在后面使用,求至少需要多少次乘。如24:2*2=22(第一次乘),22*22=24(第二次乘),所以最少共2次;

               

 
输入
第一行m表示有m(1<=m<=100)组测试数据;
每一组测试数据有一整数n(0<n<=10000);
输出
输出每组测试数据所需次数s;
样例输入
3
2
3
4
样例输出
1
2
2
上传者
李剑锋
解题:快速幂。。。弱菜。。。几个月前时的我居然不会。。。
bubuko.com,布布扣
 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cstring>
 4 #include <cmath>
 5 #include <algorithm>
 6 #include <climits>
 7 #include <vector>
 8 #include <queue>
 9 #include <cstdlib>
10 #include <string>
11 #include <set>
12 #include <stack>
13 #define LL long long
14 #define pii pair<int,int>
15 #define INF 0x3f3f3f3f
16 using namespace std;
17 int ans;
18 void Fast(int n){
19     while(n){
20         if(n&1) ans++;
21         n >>= 1;
22         if(n) ans += 1;
23     }
24 }
25 int main() {
26     int n,m;
27     scanf("%d",&n);
28     while(n--){
29         scanf("%d",&m);
30         ans = 0;
31         Fast(m);
32         printf("%d\n",ans?ans-1:ans);
33     }
34     return 0;
35 }
View Code

 

NYIST 46 最少乘法次数

原文:http://www.cnblogs.com/crackpotisback/p/4078833.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!