1. 程式人生 > >洛谷 - P1582 - 倒水 - 位運算

洛谷 - P1582 - 倒水 - 位運算

兩個 位運算 spa count() amp ref uri 倒水 運算

https://www.luogu.org/problemnew/show/P1582
要求用最少的瓶子,那肯定不能有兩個一樣的瓶子,否則合並更優.
枚舉其二進制位,每次加上lowbit,將最後一個1加上.

顯然最多logn次.

#include<bits/stdc++.h>
using namespace std;
#define ll long long

ll n,k;

int main(){
    cin>>n>>k;

    bitset<32> b(n);
    //cout<<b<<endl;

    ll sum=0;
    while(b.count()>k){
        ll cn=n&-n;
        //cout<<bitset<32>(cn)<<endl;
        n+=cn;
        sum+=cn;
        b=bitset<32>(n);
        //cout<<b<<endl;
    }

    //cout<<b<<endl;
    cout<<sum<<endl;
}

洛谷 - P1582 - 倒水 - 位運算