HDU電腦學院大學生程式設計競賽(2015’12)1005 Bitwise Equations

來源:互聯網
上載者:User

標籤:

題意:
已知x,k

求第k個使得x+y==x|y的正整數y

 

x+y==x|y

即x為1的位y為0

可知y有幾位可以為1

詳見代碼

#include<cstdio>#include<cstring>#include<string>#include<iostream>#include<algorithm>#include<map>using namespace std;const int N=50005;int n,k;int seg[66],v[66];long long m[66];int main(){    int i,j,r;    m[0]=1;    for(i=1;i<=64;i++)        m[i]=m[i-1]*2;    int T;    scanf("%d",&T);    while(T--)    {        scanf("%d%d",&n,&k);        long long ans=0;        k;        int cnt=0;        memset(v,0,sizeof(v));        for(i=1;i<=63;i++)        {            seg[i]=n%2;            n/=2;            if(seg[i]==0) v[i]=++cnt;        }        for(i=63;i>=1;i--)        {            if(v[i]==0) continue;            if(k>=m[v[i]-1]) ans+=m[i-1],k-=m[v[i]-1];        }        cout<<ans<<endl;    }    return 0;}

 

HDU電腦學院大學生程式設計競賽(2015’12)1005 Bitwise Equations

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.