D数树,牛客小白月赛78,思维

链接:登录---专业IT笔试面试备考平台_牛客网

来源:牛客网

时间限制:C/C++ 1秒,其他语言2秒

空间限制:C/C++ 262144K,其他语言524288K

64bit IO Format: %lld

题目描述

"开导!"

众所周知,树是一种特殊的图。

众所周知(二),导出子图是由该图顶点的一个子集和该图中两端均在该子集的所有边的集合组成的图。

注1:二叉树是有向图。

注2:有向图的导出子图,还是有向图。

小沙有 nnn 个节点,他需要你构造出一颗有根二叉树,使得二叉树的所有导出子图是一颗满二叉树的数目尽可能多。

请问构造出来的有根二叉树的所有导出子图是一颗满二叉树的数目最多是多少?

你能帮帮不会数/树的小沙吗?

输入描述:

复制代码

第一行读入一个整数 TTT ,代表多组样例。

随后 TTT 行,每行输入一个正整数 nnn。

保证有 1≤T≤1051 \le T \le 10^51≤T≤105,1≤n≤10181 \le n \le 10^{18}1≤n≤1018。

输出描述:

复制代码

对于每组样例输出一行整数代表答案。

由于答案过大,所以请输出答案对 109+710^9 + 7109+7 取模的值。

示例1

输入

复制10 1 2 3 4 5 6 7 8 9 10

复制代码
10
1
2
3
4
5
6
7
8
9
10

输出

复制1 2 4 5 7 8 11 12 14 15

复制代码
1
2
4
5
7
8
11
12
14
15

说明

复制代码

对于 777 个节点的最优二叉树为

其 111111 个导出子图为满二叉树的有

cpp 复制代码
#include<iostream>
#include<string>
#include<cstring>
#include<cmath>
#include<ctime>
#include<algorithm>
#include<utility>
#include<stack>
#include<queue>
#include<vector>
#include<set>
#include<math.h>
#include<map>

using namespace std;
typedef long long LL;
const LL mod = 1e9 + 7;
LL n;

int fun(LL a) {
	LL t = 1,ret=0;
	while (t <= a) {
		ret += a / t;
		t *= 2;
	}
	return ret;
}

int main() {
	int cnt;
	cin >> cnt;
	while (cnt--) {
		cin >> n;
		LL ans = 0;
		LL t = 1, sum = 0,p=1;
		while (sum + t <= n) {
			ans = (ans + p) % mod;
			sum += t;
			t *= 2;
			p += t;
		}
		if (n - sum > 0) {
			ans = (ans + fun(n - sum)) % mod;
		}
		cout << ans << endl;
	}
	return 0;
}
相关推荐
Lenyiin1 小时前
02.06、回文链表
数据结构·leetcode·链表
爪哇学长1 小时前
双指针算法详解:原理、应用场景及代码示例
java·数据结构·算法
爱摸鱼的孔乙己1 小时前
【数据结构】链表(leetcode)
c语言·数据结构·c++·链表·csdn
烦躁的大鼻嘎2 小时前
模拟算法实例讲解:从理论到实践的编程之旅
数据结构·c++·算法·leetcode
C++忠实粉丝2 小时前
计算机网络socket编程(4)_TCP socket API 详解
网络·数据结构·c++·网络协议·tcp/ip·计算机网络·算法
daiyang123...3 小时前
测试岗位应该学什么
数据结构
kitesxian4 小时前
Leetcode448. 找到所有数组中消失的数字(HOT100)+Leetcode139. 单词拆分(HOT100)
数据结构·算法·leetcode
薯条不要番茄酱5 小时前
数据结构-8.Java. 七大排序算法(中篇)
java·开发语言·数据结构·后端·算法·排序算法·intellij-idea
盼海7 小时前
排序算法(五)--归并排序
数据结构·算法·排序算法
搬砖的小码农_Sky13 小时前
C语言:数组
c语言·数据结构