算法入门-可爱の星空

可爱の星空

https://ac.nowcoder.com/acm/problem/20650

题意

  • 多组数据
  • 每组数据给出一个图中点的个数n,链接任意一条边需要的代价是这个边所连的两个联通块的大小的差值,使这n个点联通所需的最小代价是多少

思路

  • 贪心的思考,想让价值最小,每一步合并的两个块得大小接近
  • 最终都会合成一个联通图,逆序思考
  • 深搜即可

代码

#include<bits/stdc++.h>

using namespace std;
/**
 * 1 0
 * 2 0
 * 3 1
 * 4 0
 * 5 2
 * 6 2
 * 7 2
 * 8 0 100
 * 9 2 101
 * 10 4 110
 * 11 4
 * 12 4
 */


long long dfs(long long n){
    if(n<=2) return 0;
    else if(n==3) return 1;
    else if(n&1) return dfs(n/2)+dfs(n/2+1)+1;
    else return dfs(n/2)*2;
}

int main(){
    ios::sync_with_stdio(false);
    cin.tie(0);cout.tie(0);
    int t;
    cin >> t;
    while(t--){
        long long n;
        cin >> n;
        cout << dfs(n) << '\n';
    }
    return 0;
}
全部评论

相关推荐

08-19 18:59
已编辑
绍兴文理学院 Java
一只末影酱:一、1w+qps嘛感觉数据有点太夸张了 二、还有就是99.95%这些,本身大部分学生做的小项目基本是100%,因为量太小了,网络抖动问题也基本模拟不出来,感觉这些不太好写 三、你这些项目,都是一个月就做完了,更抽象了,也就是大概意味着,没有技术调研,没有上线测试,
点赞 评论 收藏
分享
码农顶针:估计让你免费辅导老板孩子的学习
点赞 评论 收藏
分享
pdd已经一面了,听说pdd是11116听着已经压力巨大了但是听说给的多投都投了,先面着吧
码农索隆:我认为哈,工资高加班多那是正常的,加班费啥的都正常给,那是ok的,但是加班多没加班费逼事还一堆一堆的那种公司,没必要进,进去之后,都不用吃饭,没事,就吃大饼
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务