codeforces round 949 div2
A Turtle and Piggy Are Playing a Game
题目:
思路:输出2的幂次b使得2^b为最大的不超过x的数
代码:
#include <iostream>using namespace std;const int N = 2e5 + 10;void solve() {int l, r;cin >> l >> r;if(r % 2) r --;int ans = 0;while(r != 1) {ans ++;r /= 2;}cout << ans << endl;
}int main() {int t;cin >> t;while(t -- ) {solve();}return 0;
}
当然也可以直接输出_lg(x)
B. Turtle and an Infinite Sequence
问题:

思路:实际上就是求一个区间内的or值,区间为max(0, n - m), n + m。由于区间范围很大,暴力会t,因此考虑寻找某些规律。
x:100011
y:101001
从x自增到y,发现x,y最左边两位是相等的,因此这两位相等的位只有为1时才会对答案产生贡献,这两位其他位会从小的不断自增到大的,因此这些位肯定会出现1,因此答案就是从左向右拆位直到找到第一个不同的位,这之前只有1对答案有贡献,这之后都对答案有贡献
代码:
#include <iostream>
#include <vector>
#include <algorithm>using namespace std;const int N = 2e5 + 10;int get(int x) {int cnt = 0;while(x) {cnt ++;x >>= 1;}return cnt;
}int qmi(int a) {int res = 1;int b = 2;while(a) {if(a & 1) res *= b;b *= b;a >>= 1;}return res;
}void solve() {int n, m;cin >> n >> m;int pos = -1;int x = m + n;int len = get(x);vector<int> ans;if(m == 0) cout << n << endl;else {vector<int> a;vector<int> b;for(int i = len - 1; i >= 0; i -- ) {int aa = (x >> i) & 1;int bb = (n >> i) & 1;a.push_back(aa);b.push_back(bb);}bool flag = false;for(int i = 0; i <= len - 1; i ++ ) {//cout << b[i] << " ";if(a[i] != b[i]) flag = true;if(!flag) ans.push_back(a[i]);else ans.push_back(1);}len = get(n);a.clear();b.clear();x = n;int y = max(0, n - m);for(int i = len - 1; i >= 0; i -- ) {int aa = (x >> i) & 1;int bb = (y >> i) & 1;a.push_back(aa);b.push_back(bb);}vector<int> ans1;flag = false;for(int i = 0; i <= len - 1; i ++ ) {//cout << b[i] << " ";if(a[i] != b[i]) flag = true;if(!flag) ans1.push_back(a[i]);else ans1.push_back(1);}reverse(ans.begin(), ans.end());reverse(ans1.begin(), ans1.end());for(int i = 0; i < ans1.size(); i ++ ) {ans[i] |= ans1[i];}int res = 0;for(int i = 0; i < ans.size(); i ++ ) {res += ans[i] * qmi(i);}// for(auto t: a) cout << t << " ";cout << res << endl;}
}int main() {int t;cin >> t;while(t -- ) {solve();}return 0;
}
赛后优化代码:
#include <iostream>using namespace std;void solve() {int n, m;cin >> n >> m;int l = max(0, n - m), r = n + m;int ans = 0;bool flag = false;for(int i = 30; i >= 0; i -- ) {int x = (l >> i) & 1;int y = (r >> i) & 1;if(x != y) flag = true;if(!flag) {ans += (1 << i) * x;} else ans += (1 << i) * 1;}cout << ans << endl;
}int main() {int t;cin >> t;while(t -- ) {solve();}return 0;
}
C: Turtle and an Incomplete Sequence
题目:
思路:先特判,特判掉都是-1的以及只有一个非-1数。特判之后记录所有非-1数的位置对于第一个位置和最后一个位置让他们分别向左右扫,不断除2,如果变成0就赋值-1.对于任意两位置pos[i] pos[i + 1]让他们两个向中间靠拢,哪个大就/2如果变成0就置2 最后当strat + 1 = end时判断下相邻元素是否合法。对于这种解法的正确性可以考虑一颗二叉树(父节点u 左子节点2u 右子节点2u + 1),有两个节点,两个节点不断除2最终一定会到他们的lca上.
代码:
#include <iostream>
#include <vector>using namespace std;const int N = 2e5 + 10;int a[N];
int n;void solve() {cin >> n;vector<int> pos;vector<int> b(n + 5);for(int i = 1; i <= n; i ++ ) {cin >> a[i];if(a[i] != -1) {pos.push_back(i);b[i] = a[i];} }if(!pos.size()) {b[1] = 1;for(int i = 2; i <= n; i ++ ) {b[i] = b[i - 1] / 2;if(b[i] == 0) b[i] = 2;}for(int i = 1; i <= n; i ++ ) cout << b[i] << " ";cout << endl;return;}if(pos.size() == 1) {for(int i = pos[0]; i >= 1; i -- ) {b[i - 1] = b[i] / 2;if(b[i - 1] == 0) b[i - 1] = 2;}for(int i = pos[0]; i <= n; i ++ ) {b[i + 1] = b[i] / 2;if(b[i + 1] == 0) b[i + 1] = 2;}for(int i = 1; i <= n; i ++ ) cout << b[i] << " ";cout << endl;return; }for(int i = 0; i < pos.size() - 1; i ++ ) {int start = pos[i];int end = pos[i + 1];if(i == 0) for(int j = start - 1; j >= 1; j -- ) {b[j] = b[j + 1] / 2;if(b[j] == 0) b[j] = 2;}if(i + 1 == pos.size() - 1) for(int j = end + 1; j <= n; j ++ ) {b[j] = b[j - 1] / 2;if(b[j] == 0) b[j] = 2;}while(start + 1 < end) {if(b[start] >= b[end]) {start ++;b[start] = b[start - 1] / 2;if(b[start] == 0) b[start] = 2;} else {end --;b[end] = b[end + 1] / 2;if(b[end] == 0) b[end] = 2;}}if(b[start] != b[end] / 2 && b[end] != b[start] / 2) {cout << "-1" << endl;return;}}for(int i = 1; i <= n; i ++ ) cout << b[i] << " ";cout << endl;
}int main() {int t;cin >> t;while(t -- ) {solve();}return 0;
}
D Turtle and Multiplication
题目:
思路:优先考虑素数,于是问题转化为了在当前数量的素数中是否可以找到一条欧拉通路。点数可以用二分查找,当查找到奇数点时,由于完全连通图各点是度数为偶数,因此一定存在欧拉通路,对于偶数点,所有点度数为奇数,由于每删去一条边可以使得最多两个点度数变成偶数,因此至少要删去x / 2 - 1条边可以使得图中存在欧拉通路。因此建图后跑一遍欧拉路即可
代码:不知道什么原因1 1000000这个样例过不去,有时间再说吧
#include <iostream>
#include <cstring>
#include <vector>using namespace std;const int N = 1e6 + 1000;vector<int> seq;
int n, cnt;
int prime[N];
int val[N * 2], ne[N * 2], h[N], idx;
bool st[N], used[N * 2];void add(int a, int b) {val[idx] = b;ne[idx] = h[a];h[a] = idx ++;
}void is_prime(int x) {for(int i = 2; i <= x; i ++ ) {if(!st[i]) prime[cnt ++] = i;for(int j = 0; prime[j] <= x / i; j ++ ) {st[prime[j] * i] = true;if(i % prime[j] == 0) break;}}
}bool check(int x) {if(x & 1) {int cnt = x + (x * (x - 1)) / 2;return cnt >= n - 1;} else {int cnt = x + (x * (x - 1)) / 2 - x / 2 + 1;return cnt >= n - 1;}
}void dfs(int u) {while(h[u] != -1) {int i = h[u];if(used[i]) {h[u] = ne[i];continue;}used[i] = 1;used[i ^ 1] = 1;h[u] = ne[i];dfs(val[i]);seq.push_back(val[i]);}
}/*void dfs(int u) {for(int i = h[u]; i != -1; i = ne[i]) {if(used[i]) {h[u] = ne[i];continue;}used[i] = 1;used[i ^ 1] = 1;h[u] = ne[i];dfs(val[i]);seq.push_back(val[i]);}
}*/void init() {for(int i = 1; i <= 2 * n + 5000; i ++ ) used[i] = 0; memset(h, -1, sizeof h);idx = 0;seq.clear();
}void solve() {init();cin >> n;int l = 1, r = 2000;//二分点数while(l < r) {int mid = l + r >> 1;if(check(mid)) r = mid;else l = mid + 1;}if(l & 1) {for(int i = 0; i < l; i ++ ) {for(int j = i; j < l; j ++ ) {add(prime[i], prime[j]);add(prime[j], prime[i]);}}} else {int judge = 0;int cnt = l / 2 - 1;for(int i = 0; i < l; i ++ ) {for(int j = i; j < l; j ++ ) {if(j == i + 1) {judge ++;if(!(judge & 1)) {continue;}}add(prime[i], prime[j]);add(prime[j], prime[i]);}}}dfs(2);int len = seq.size();for(int i = 0; i < min(len, n); i ++ ) cout << seq[i] << " ";if(len < n) cout << 2;cout << endl;
}int main() {is_prime(200000);int t;cin >> t;while(t -- ) {solve();}return 0;
}
E:
相关文章:
codeforces round 949 div2
A Turtle and Piggy Are Playing a Game 题目: 思路:输出2的幂次b使得2^b为最大的不超过x的数 代码: #include <iostream>using namespace std;const int N 2e5 10;void solve() {int l, r;cin >> l >> r;if(r % 2) …...
分享美好,高清无阻 - 直播极简联网解决方案
1、需求背景 随着移动互联网、UGC模式和直播平台的发展,网络直播的门槛日益降低,越来越多的人希望成为直播的主角。基于物联网的户外直播无线联网解决方案应运而生,满足直播者的需求。 户外直播无线联网解决方案提供了无处不在的直播体验&a…...
贪心算法-加油站
一、题目描述 二、解题思路 1.运动过程分析 这里需要一个油箱剩余油量的变量resGas,初始化resGas0;还需要一个标记从什么位置当做初始位置的startIdx,初始化startIdx0。 我们从数组下标idx0处开始向后遍历,初始时startIdx0&#…...
【ArcGIS微课1000例】0116:将度-分-秒值转换为十进制度值(字段计算器VBA)
相关阅读:【ArcGIS微课1000例】0087:经纬度格式转换(度分秒转度、度转度分秒) 文章目录 一、计算方法二、计算案例一、计算方法 将度分秒转换为十进制度的简单等式: DD = (Seconds/3600) + (Minutes/60) + Degrees如果角度值是负数,则转换方法不同。其中一种方法是: …...
【中国开源生态再添一员】天工AI开源自家的Skywork
刚刚看到《AI高考作文出圈,网友票选天工AI居首》,没想到在Huggingface中发现了Skywork大模型。天工大模型由昆仑万维自研,是国内首个对标ChatGPT的双千亿级大语言模型,天工大模型通过自然语言与用户进行问答式交互,AI生…...
【机器学习300问】109、什么是岭回归模型?
在进行回归任务时间,可以能会遇到特征数量多于观测数量或某些特征变量之间相关性较高(几乎线性相关)时,标准的线性回归模型的系数估计可能非常不精确,可以理解成独立方程个数小于未知数个数此时方程有无穷多解。 例如&…...
FJSP:烟花算法(FWA)求解柔性作业车间调度问题(FJSP),提供MATLAB代码
一、烟花算法介绍 参考文献: Tan, Y. and Y. Zhu. Fireworks Algorithm for Optimization. in Advances in Swarm Intelligence. 2010. Berlin, Heidelberg: Springer Berlin Heidelberg. 二、烟花算法求解FJSP 2.1FJSP模型介绍 柔性作业车间调度问题(Flexible …...
C++11 列表初始化(initializer_list),pair
1. {} 初始化 C98 中,允许使用 {} 对数组进行初始化。 int arr[3] { 0, 1, 2 };C11 扩大了 {} 初始化 的使用范围,使其可用于所有内置类型和自定义类型。 struct Date {int _year;int _month;int _day;Date(int year, int month, int day):_year(year…...
Python3 笔记:字符串的 startswith() 和 endswith()
1、startswith() 方法用于检查字符串是否是以指定子字符串开头,如果是则返回 True,否则返回 False。如果参数 beg 和 end 指定了值,则在指定范围内检查。 语法:str.startswith(substr, beg0,endlen(string)) 参数: s…...
Web前端安全问题分类综合以及XSS、CSRF、SQL注入、DoS/DDoS攻击、会话劫持、点击劫持等详解,增强生产安全意识
前端安全问题是指发生在浏览器、单页面应用、Web页面等前端环境中的各类安全隐患。Web前端作为与用户直接交互的界面,其安全性问题直接关系到用户体验和数据安全。近年来,随着前端技术的快速发展,Web前端安全问题也日益凸显。因此,…...
1.单选题 (2分)下列关于脚本的说法不正确的是( )。本题得分: 2分正确答案: A2.单选题 (2分)软件测试自动化的局限性不包含( )。本题得分: 2分
1.单选题 (2分) 下列关于脚本的说法不正确的是( )。 A 线性脚本是最复杂的脚本 B 结构化脚本具有较好的可读性、可重用性,易于维护 C 关键字驱动脚本在开发时,不关心基础函数,直接使用已定义好的关键字 D 数据驱动脚本将测试脚本和数据进行分离,同一个脚本可以针对不同的输…...
【Docker系列】跨平台 Docker 镜像构建:深入理解`--platform`参数
💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…...
力扣1248.统计优美子数组
力扣1248.统计优美子数组 同930. 哈希表法 求前缀和 class Solution {public:int numberOfSubarrays(vector<int>& nums, int k) {int n nums.size();unordered_map<int,int> cnt;int res0,sum0;for(int i0,j0;i<n;i){cnt[sum] ;if(nums[i] & 1) …...
AI2THOR 2.1.0使用教程
一、安装和入门 1.1 AI2-THOR使用要求 操作系统: Mac OS X 10.9, Ubuntu 14.04显卡:DX9(着色器型号 3.0)或 DX11,功能级别为 9.3。CPU:支持 SSE2 指令集。Python 2.7 或 Python 3.5Linux 用户…...
在Nginx中配置php程序环境。
1、前言。 我一开始是想 搭建 Tomcat PHP 环境。 Tomcat并不能直接运行PHP,因为Tomcat是一个Java Web服务器,主要用于运行Java应用程序。但是,我们可以通过一些配置和工具来使Tomcat能够运行PHP。 在配置Tomcat支持PHP 项目的时…...
!力扣70. 爬楼梯
假设你正在爬楼梯。需要 n 阶你才能到达楼顶。每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢? 1. 递归(超时) class Solution { public:int climbStairs(int n) {if(n1){return 1;}if(n2){return 2;}return climbStairs…...
Spring boot+vue前后端分离
目录 1、前端vue的搭建 2、后端项目的构建 pom文件中引入的jar包 yml文件用来配置连接数据库和端口的设置 application.property进行一些整合 service层 imp层 mapper 实体类 额外写一个类、解决跨域问题 3、测试 1、前端vue的搭建 建立项目的过程略 开启一个建立好…...
Python基础总结之列表转字符串
Python基础总结之列表转字符串 在Python中,将列表转换为字符串有多种方法,最常用的是使用str.join()方法。这里有一些示例: 使用str.join()方法 这是将列表转换为字符串的最直接和最常用的方法。你需要确保列表中的所有元素都是字符串类型…...
二分【1】二分查找框架 查找指定元素
目录 二分查找 基本思想 几种情况汇总 一。严格递增序列 1.查找本身 2.查找第一个大于等于自己的 3.查找第一个大于自己的 4.严格递减序列 二。有重复元素 1.取其中第一个出现的 2.取其中最后一个出现的 二分查找 基本思想 几种情况汇总 一。严格递增序列 1.查找本身…...
Python 中如何使用 lambda 函数
在 Python 中,可以使用 lambda 函数来创建匿名函数。lambda 函数的语法是:lambda 参数: 表达式。以下是一些使用 lambda 函数的例子: 通过 lambda 函数来计算两个数的和: add lambda x, y: x y print(add(2, 3)) # 输出 5通过…...
基于MATLAB与SVM实现河道水面漂浮物的自动检测与识别
摘要:河道水面漂浮物不仅影响水环境质量,还威胁水利设施安全和水生态健康。传统人工巡检方式效率低、成本高,难以满足大范围、实时化的 监测需求。针对上述问题,本文基于 MATLAB 平台,结合支持向量机(SVM&a…...
数据治理与数据质量:从策略到实践
数据治理与数据质量:从策略到实践 前言 作为一个在数据深渊里捞了十几年 Bug 的女码农,我深知数据治理和数据质量在企业数据管理中的重要性。随着数据量的爆炸式增长和数据类型的多样化,数据治理和数据质量已经成为企业数据管理的核心挑战。今…...
2026届最火的六大降重复率神器实际效果
Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 目前人工智能生成内容大范围运用的情形下,致使 AIGC 检测识别率降低的工具适时出…...
剧本杀app2025推荐,多类型剧本体验与社交互动优势
剧本杀app2025推荐,多类型剧本体验与社交互动优势在当今娱乐多元化的时代,剧本杀凭借其独特的角色扮演和推理乐趣,成为了众多年轻人喜爱的社交娱乐方式。据《2025 年中国剧本杀行业发展报告》显示,2025 年剧本杀市场规模持续增长&…...
09_微服务划分与团队人数之阿里实践与行业案例
微服务划分与团队人数之阿里实践与行业案例 体系内容 拆分维度:业务能力维度、通用能力维度、非功能维度 组织原则:康威定律、领域自治、平台沉淀、核心/非核心差异化治理 Spring Cloud Alibaba 视角:Nacos、Sentinel、RocketMQ、Seata、Dubbo 在企业场景中的组合打法 行业…...
利用drawio高效绘制数据库ER图:从入门到精通
1. 为什么选择drawio绘制数据库ER图 第一次接触数据库设计时,我被各种专业工具的价格和复杂度吓退了。直到发现drawio这个宝藏工具,才真正体会到什么叫"用最简单的工具做专业的事"。作为一款完全免费的跨平台工具,drawio不仅支持网…...
Flutter Web:混合开发的最佳实践
Flutter Web:混合开发的最佳实践一次编写,多端运行。Flutter Web 让前端开发更加高效。一、Flutter Web 的优势 作为一名追求像素级还原的 UI 匠人,我对跨平台解决方案有着严格的要求。Flutter Web 不仅让我们能够使用相同的代码库构建 Andro…...
无人船编队 无人车编队 MPC 模型预测控制 多智能体协同控制 一致性 MATLAB 无人车 USV
无人船编队 无人车编队 MPC 模型预测控制 多智能体协同控制 一致性 MATLAB 无人车 USV 带原文献一、代码核心定位与应用场景 本套MATLAB源码针对自主水下航行器(AUV)、无人船(USV)、无人车等多智能体系统,实现了基于事…...
旋转ReDet目标检测环境配置、旋转ReDet目标检测模型代跑训练、旋转ReDet目标检测模型改进创新旋转ReDet目标检测环境配置:Windows、Ubuntu、Centos、Macos等系统
旋转ReDet目标检测环境配置、 旋转ReDet目标检测模型代跑训练、 旋转ReDet目标检测模型改进创新 旋转ReDet目标检测环境配置:Windows、Ubuntu、Centos、Macos等系统环境,如果电脑拥有显卡,可配置GPU版本的ReDet环境。 旋转ReDet目标检测模型代…...
MaaYuan自动化辅助工具高效配置避坑指南:零基础入门三步完成环境部署
MaaYuan自动化辅助工具高效配置避坑指南:零基础入门三步完成环境部署 【免费下载链接】MaaYuan 代号鸢 / 如鸢 一键长草小助手 项目地址: https://gitcode.com/gh_mirrors/ma/MaaYuan MaaYuan作为一款基于MaaFramework的自动化辅助工具,专为游戏日…...
