枚举+二分,CF 325B - Stadium and Games

ops/2024/10/21 9:49:46/

目录

一、题目

1、题目描述

2、输入输出

2.1输入

2.2输出

3、原题链接

二、解题报告

1、思路分析

2、复杂度

3、代码详解


一、题目

1、题目描述

2、输入输出

2.1输入

2.2输出

3、原题链接

325B - Stadium and Games


二、解题报告

1、思路分析

考虑 一个可能的初始队伍数目 num 的 变化历程

除2,除2,除2 ……=> 变为 奇数m,m * (m - 1) / 2

假如除了 i 次2,变为奇数m

那么有 m * (2^i - 1) + (m - 1) * m / 2 = n

因为指数增长很快,2^60 都已经超过1E18了

我们发现合法的 i 其实很少

而一旦 i 固定,式子关于 m 就是单调递增的

于是想到 枚举 i,二分 m

问题迎刃而解

2、复杂度

时间复杂度: O(log^2 n)空间复杂度:O(1)

3、代码详解

 ​
#include <bits/stdc++.h>// #define DEBUGusing u32 = unsigned;
using i64 = long long;
using u64 = unsigned long long;constexpr int inf32 = 1E9 + 7;
constexpr i64 inf64 = 1E18 + 7;void solve() {i64 n;std::cin >> n;bool f = 0;for (int i = 0; i < 60; ++ i) {i64 v = 1LL << i;i64 lo = 0, hi = std::min(1LL << 31, n / std::max(v - 1, 1LL));while (lo < hi) {i64 x = lo + (hi - lo) / 2;if (x * (v - 1) + x * (x - 1) / 2 >= n) hi = x;else lo = x + 1;}if (hi * (v - 1) + hi * (hi - 1) / 2 == n && (hi & 1)) {std::cout << hi * v << '\n';f = true;}}if (!f) std::cout << "-1\n";
}int main() {std::ios::sync_with_stdio(false);std::cin.tie(nullptr);#ifdef DEBUGint cur = clock();freopen("in.txt", "r", stdin);freopen("out.txt", "w", stdout);
#endifint t = 1;// std::cin >> t;while (t--) {solve();}
#ifdef DEBUGstd::cerr << "run-time: " << clock() - cur << '\n';
#endifreturn 0;
}


http://www.ppmy.cn/ops/123395.html

相关文章

Python大数据学习之Hadoop学习——day08_hive函数

一.hive查询 语法结构&#xff1a; SELECT [ALL | DISTINCT] 字段名&#xff0c;字段名,... FROM 表名 [inner | left outer | right outer | full outer | left semi join 表名 on 关联条件] [where 非聚合条件] [GROUP BY 分组字段名] [HAVING 聚合条件] [ORDER BY 排序字段…

机器学习——多模态学习

多模态学习&#xff1a;机器学习领域的新视野 引言 多模态学习&#xff08;Multimodal Learning&#xff09;是机器学习中的一个前沿领域&#xff0c;它涉及处理和整合来自多个数据模式&#xff08;如图像、文本、音频等&#xff09;的信息。随着深度学习的蓬勃发展&#xff0…

【算法】链表:2.两数相加(medium)+模拟

系列专栏 《分治》 《模拟》 《Linux》 目录 1、题目链接 2、题目介绍 3、解法 (模拟) 4、代码 1、题目链接 2. 两数相加 - 力扣&#xff08;LeetCode&#xff09; 2、题目介绍 3、解法 (模拟) 理解题目要求&#xff1a; 我们有两个链表&#xff0c;每个链表代表一个…

LeetCode讲解篇之1143. 最长公共子序列

文章目录 题目描述题解思路题解代码题目链接 题目描述 题解思路 这题我们可以采用动态规划求解&#xff0c;用一个二维数组记录text1的0 ~ i区间子串和text2的0 ~ j区间子串的最长公共子序列的长度&#xff0c;我们假设该二维数组是f 这个数组有一个特性&#xff0c;如果a <…

MyBatis之TypeHandler的自定义实现

文章目录 一、TypeHandler概述二、TypeHandler的工作原理1.设置参数&#xff08;Parameter Setting&#xff09;2.获取结果&#xff08;Result Getting&#xff09;3.类型映射和转换规则4.自定义TypeHandler的扩展性 三、自定义的具体实现业务场景分析需求具体实现 一、TypeHan…

数据结构——排序(交换排序)

目录 一、交换排序的总体概念 二、冒泡排序 三、快速排序 1.挖坑法 2.左右指针 3.前后指针 一、交换排序的总体概念 交换排序是一类排序算法&#xff0c;它的核心思想是通过交换元素的位置来达到排序的目的。在排序过程中&#xff0c;比较数组中的元素对&#xff0c;如果…

RTC -

RTC 目录 RTC 回顾 RTC 如何实现RTC制作一个时钟日历 代码编写 rtc.c完整代码 模块开发的步骤&#xff1a; 1、找文档 2、 在文档里面找通信方式&#xff0c;通信过程&#xff08;协议&#xff09; 3、代码> -- 前面学的是模块的开发&#xff0c;串口类&#xff0c;I…

Expectation-Maximization Algorithm(EM算法)

EM算法&#xff08;Expectation-Maximization Algorithm&#xff0c;期望最大化算法&#xff09;是一种迭代优化算法&#xff0c;主要用于在含有隐变量&#xff08;未观测变量&#xff09;或不完全数据的概率模型中&#xff0c;估计参数的最大似然估计&#xff08;Maximum Like…