首页 > 其他分享 >排列与二进制【吉林大学考研机试题】

排列与二进制【吉林大学考研机试题】

时间:2023-02-27 18:24:45浏览次数:32  
标签:10 排列 二进制 吉林大学 int include 输入 考研

排列与二进制

在组合数学中,我们学过排列数。

从 n 个不同元素中取出 m(m<=n)个元素的所有排列的个数,叫做从 n 中取 m 的排列数,记为 p(n,m)。

具体计算方法为 p(n,m)=n(n−1)(n−2)……(n−m+1)=n!/(n−m)!(规定 0!=1)。

当 n 和 m 不是很小时,这个排列数是比较大的数值,比如 p(10,5)=30240。

如果用二进制表示为 p(10,5)=30240=(111011000100000)b,也就是说,最后面有 5 个零。

我们的问题就是,给定一个排列数,算出其二进制表示的后面有多少个连续的零。

输入格式
输入包含多组测试数据。

每组数据占一行,包含两个整数 n,m。

最后一行为 0 0,表示输入结束,无需处理。

输出格式
每组数据输出一行,一个结果,表示排列数 p(n,m) 的二进制表示后面有多少个连续的零。

数据范围
1≤m≤n≤10000,
输入最多包含 100 组数据。

输入样例:
10 5
6 1
0 0
输出样例:
5
1

思路

求乘积二进制有多少个连续的零,即求各个因子有多少个连续的0求和即可(注意这里暴力会tle)
i&-i得到的是最后二进制中最后1个1与后面的0所组成的数,求log可得

\[A_{n}^{m} = n(n−1)(n−2)……(n−m+1) = 2^k * x \]

\[2^k = 2^{k_{n-m+1}+...+k_n} \]

代码

点击查看代码
#include<iostream>
#include<cmath>
using namespace std;

int main(){
    int n,m;
    while(cin >> n && cin >> m){
        if(!n && !m)break;
        long long ans = 0;
        for(int i = n - m + 1; i <= n; i ++)ans += log2(i&-i);
        cout << ans << '\n';
    }
}

标签:10,排列,二进制,吉林大学,int,include,输入,考研
From: https://www.cnblogs.com/J-12045/p/17161399.html

相关文章

  • 计算机的存储规则二进制和其他进制和分辨率
                                           ......
  • 运行klayout编译出的二进制文件报错 libklayout_bd.so.1
    错误提示如下解决方法将编译输出目录添加到环境变量编辑~/.bashrc,添加以下代码exportLD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/qqs/桌面/klayout-0.28.5/build-klay......
  • 12进制转10进制再转2进制【华中科技大学考研机试题】
    12进制转10进制再转2进制十二进制是数学中一种以12为底数的计数系统,它由0∼9,a,b组成,与十进制的对应关系是:0∼9对应0∼9,a对应10,b对应11。例如,十二进制的a2,十进制是......
  • 16进制转10进制【北京大学考研机试题】
    16进制转10进制写出一个程序,输入一个十六进制的数值字符串,输出该数值的十进制字符串。输入格式输入包含多组测试数据。每组数据占一行,包含一个十六进制的数值字符串。......
  • 十进制转八进制【华中科技大学考研机试题】
    十进制转八进制点击查看代码输入一个整数N,将其转换成八进制数输出。输入格式输入包含多组测试数据。每组数据占一行,包含一个整数N。输出格式每组数据输出占......
  • 二进制中1的个数
    二进制中1的个数输入一个32位整数,输出该数二进制表示中1的个数。注意:负数在计算机中用其绝对值的补码来表示。数据范围−100≤输入整数≤100样例1输入:9输出:2......
  • 考研周记-week1
    2.20~2.26本周考研开始的第一周,准备从本次开始记录考研的每一个周学的知识和记录每周发生的事英语每天早上起来吃完饭之后,就开始背单词,每天背60个单词,还有复习的单词,平......
  • c语言,16进制,二进制,十进制递增(++)后结果
    uint32_ti=0x00u//无符号16进制for(inty=0;y<20;y++){i++;}//i=0x00在十进制表示是0,经过循环每次+1,第一次进入循环十进制为0+1=0;第二次十进制表示为2......
  • 二进制文件
    写二进制文件//写二进制文件voidtest0(){ofstreamofs;ofs.open("dog.txt",ios::out|ios::binary);//以二进制方式写文件Dogd;of......
  • 三种方法写一个函数统计二进制中1的个数
    第一种方法#include<stdio.h>intcount_bit(unsignedintn){intcount=0;while(n){if(n%2==1)count++;n=n/2;}returncount;}intmain(){intn=......