HDOJ(HDU) 2502 月之数(进制)
Problem Description 
当寒月还在读大一的时候,他在一本武林秘籍中(据后来考证,估计是计算机基础,狂汗-ing),发现了神奇的二进制数。 
如果一个正整数m表示成二进制,它的位数为n(不包含前导0),寒月称它为一个n二进制数。所有的n二进制数中,1的总个数被称为n对应的月之数。 
例如,3二进制数总共有4个,分别是4(100)、5(101)、6(110)、7(111),他们中1的个数一共是1+2+2+3=8,所以3对应的月之数就是8。
Input 
给你一个整数T,表示输入数据的组数,接下来有T行,每行包含一个正整数 n(1<=n<=20)。
Output 
对于每个n ,在一行内输出n对应的月之数。
Sample Input 
3 
1 
2 
3
Sample Output 
1 
3 
8
这个题目。。用Java来计算会超时0.0
n位二进制数一共有x=2^(n-1)个数,然后举几个例子就可以看出来了: 
例如: 
输入4,则一共有如下这么多4位二进制数: 
1 0 0 0 
1 0 0 1 
1 0 1 0 
1 0 1 1 
1 1 0 0 
1 1 0 1 
1 1 1 0 
1 1 1 1 
第一列有x个1,以后每列都有x/2个1,然后一共有s=x+(n-1)*x/2个1
JavaAC:
import java.util.Scanner;
public class Main{
    public static void main(String[] args) {
        Scanner sc= new Scanner(System.in);
        int t =sc.nextInt();
        while(t-->0){
            int n =sc.nextInt();
            int cont =0;
            int x = (int)Math.pow(2, n-1);
            //int x = (int)Math.pow(2, n)-(int)Math.pow(2, n-1);//一样的
            cont+=x*(n-1)/2;
            System.out.println(cont+x);
        }
    }
}
C模拟输出: 
(这个用Java会超时)
#include <iostream>
#include <stdio.h>
#include<math.h>
using namespace std;
int main()
{
        int t ;
        scanf("%d",&t);
        while(t-->0){
            int n ;
            int cont =0;
            int x;
            scanf("%d",&n);
            for(int i=pow(2, n-1);i<=pow(2, n)-1;i++){
                x=i;
                while(x>0)
                {
                    if((x%2)==1)
                        cont++;
                    x/=2;
                }
            }
            printf("%d\n",cont);
        }
    }
HDOJ(HDU) 2502 月之数(进制)的更多相关文章
- HDOJ(HDU) 2097 Sky数(进制)
		
Problem Description Sky从小喜欢奇特的东西,而且天生对数字特别敏感,一次偶然的机会,他发现了一个有趣的四位数2992,这个数,它的十进制数表示,其四位数字之和为2+9+9+2=2 ...
 - HDU 2502 月之数(二进制,规律)
		
月之数 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submis ...
 - HDOJ(HDU) 2106 decimal system(进制相互转换问题)
		
Problem Description As we know , we always use the decimal system in our common life, even using the ...
 - HDU 2097 Sky数 进制转换
		
解题报告:这题就用一个进制转换的函数就可以了,不需要转换成相应的进制数,只要求出相应进制的数的各位的和就可以了. #include<cstdio> #include<string&g ...
 - HDU 2502 月之数(简单递推)
		
月之数 Problem Description 当寒月还在读大一的时候,他在一本武林秘籍中(据后来考证,估计是计算机基础,狂汗-ing),发现了神奇的二进制数.如果一个正整数m表示成二进制,它的位数为 ...
 - hdoj 2502  月之数
		
月之数 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
 - HDU 2106 decimal system (进制转化求和)
		
题意:给你n个r进制数,让你求和. 析:思路就是先转化成十进制,再加和. 代码如下: #include <iostream> #include <cstdio> #includ ...
 - HDU 3001 Travelling  3进制状压dp
		
题意:10个点,若干条边,边有花费,每个点最多走两次,求走过所有点,花费最少 分析:因为每个点最多走两次,所以联想到3进制,然后枚举状态,就行了(我也是照着网上大神的代码写的) #include &l ...
 - HDOJ(HDU) 1406 完数
		
Problem Description 完数的定义:如果一个大于1的正整数的所有因子之和等于它的本身,则称这个数是完数,比如6,28都是完数:6=1+2+3:28=1+2+4+7+14. 本题的任务是 ...
 
随机推荐
- ES6数组去重
			
今天五一,在出去玩之前赶紧写篇博客,时刻不要忘记学习^_^!! 提到数组去重,想必大家都不陌生,会的同学可能噼里啪啦写出好几个,下面来看看之前常见的去重代码: 'use strict'; var ar ...
 - uap--studio设置文本字体
 - java 字符串转int
			
//字符转整形 String aa = "23"; //int bb = Integer.parseInt(aa);//两种方式都是可以的 int bb = new Integer ...
 - 读取xml字符串
			
string strXml = @"<MessageData><pm_id>10</pm_id><pm_title>这是公司或者产品的名称&l ...
 - java对象与xml相互转换 ----  xstream
			
XStream是一个Java对象和XML相互转换的工具,很好很强大.提供了所有的基础类型.数组.集合等类型直接转换的支持. XStream中的核心类就是XStream类,一般来说,熟悉这个类基本就够用 ...
 - IsPostBack and DropdownList.
			
Encounted the issue accident when helping my classmate dealing with his homework assignment,it turns ...
 - Ubuntu系统中安装RPM格式包的方法
			
Ubuntu的软件包格式为deb,而RPM格式的包则是Red Hat 相关系统所用的软件包.当我们看到一个想用的软件包时,如果他是RPM格式,而你的操作系统是Ubuntu,那岂不是很遗憾?其实,在Ub ...
 - 解决UITableView中Cell重用机制导致内容出错的方法总结
			
UITableView继承自UIScrollview,是苹果为我们封装好的一个基于scroll的控件.上面主要是一个个的 UITableViewCell,可以让UITableViewCell响应一些点 ...
 - 使用soapUI代替WSDL2JAVA生成cxf HTTPS 客户端调用代码
			
如果直接用cxf下面的wsdl2java生成https服务调用代码,会报https证书的错误.在你不想导入证书的情况下,可以使用soapUI进行客户端代码的生成,步骤如下: 1.设置CXF,如下图: ...
 - Invoke()/BeginInvoke()区别
			
查看MSDN如下: Control..::.Invoke ---> 在拥有此控件的基础窗口句柄的线程上执行委托. Control..::.BeginInvoke ---> ...