zoukankan      html  css  js  c++  java
  • 权势二进制(51Nod 1413)

    一个十进制整数被叫做权势二进制,当他的十进制表示的时候只由0或1组成。例如0,1,101,110011都是权势二进制而2,12,900不是。

    当给定一个n的时候,计算一下最少要多少个权势二进制相加才能得到n。

    Input

    单组测试数据。 
    第一行给出一个整数n (1<=n<=1,000,000)

    Output

    输出答案占一行。

    Sample Input

    9

    Sample Output

    9

    题解:无论给的什么数,只要找到这个数中每个位中最大的那个数x就可以了,用x个数,每个数都是这么长度的,其他位数的0和1自由分配就能组合成这样的数。

    #include <cstdio>
    #include <cmath>
    #include <iostream>
    #include <algorithm>
    #include <cstring>
    #include <map>
    using namespace std;
    typedef long long ll;
    char s[55];  // 如果位数很大,字符串就很好的优势了。
    int main()
    {
        cin >> s;
        int m = -1;
        int n = strlen(s);
        for(int i = 0; i < n; i ++){
            if(s[i] - '0' > m)m = s[i] - '0';
        }
        printf("%d
    ",m);
        return 0;
    }
    #include <stdio.h>
    #include <stdlib.h>
    int main()
    {
        int n;
        int max = -1;
        scanf("%d",&n);
        while(n)
        {
            int x = n % 10;
            if(x > max) max = x;
            n = n / 10;
        }
        printf("%d
    ", max);
        return 0;
    }
  • 相关阅读:
    习题4.7利用vector实现数据复制
    习题4.18
    4.8编写一小段程序实现两vector是否相等的比较
    关于野指针
    学习c++的50条忠告
    c++头文件
    习题4.14
    容器和迭代器
    Android上C++对象的自动回收机制分析
    Windows下载Android源码
  • 原文地址:https://www.cnblogs.com/lcchy/p/10139581.html
Copyright © 2011-2022 走看看