当前位置: 首页 > news >正文

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 题目&#xff1a; 思路&#xff1a;输出2的幂次b使得2^b为最大的不超过x的数 代码&#xff1a; #include <iostream>using namespace std;const int N 2e5 10;void solve() {int l, r;cin >> l >> r;if(r % 2) …...

分享美好,高清无阻 - 直播极简联网解决方案

1、需求背景 随着移动互联网、UGC模式和直播平台的发展&#xff0c;网络直播的门槛日益降低&#xff0c;越来越多的人希望成为直播的主角。基于物联网的户外直播无线联网解决方案应运而生&#xff0c;满足直播者的需求。 户外直播无线联网解决方案提供了无处不在的直播体验&a…...

贪心算法-加油站

一、题目描述 二、解题思路 1.运动过程分析 这里需要一个油箱剩余油量的变量resGas&#xff0c;初始化resGas0&#xff1b;还需要一个标记从什么位置当做初始位置的startIdx&#xff0c;初始化startIdx0。 我们从数组下标idx0处开始向后遍历&#xff0c;初始时startIdx0&#…...

【ArcGIS微课1000例】0116:将度-分-秒值转换为十进制度值(字段计算器VBA)

相关阅读:【ArcGIS微课1000例】0087:经纬度格式转换(度分秒转度、度转度分秒) 文章目录 一、计算方法二、计算案例一、计算方法 将度分秒转换为十进制度的简单等式: DD = (Seconds/3600) + (Minutes/60) + Degrees如果角度值是负数,则转换方法不同。其中一种方法是: …...

【中国开源生态再添一员】天工AI开源自家的Skywork

刚刚看到《AI高考作文出圈&#xff0c;网友票选天工AI居首》&#xff0c;没想到在Huggingface中发现了Skywork大模型。天工大模型由昆仑万维自研&#xff0c;是国内首个对标ChatGPT的双千亿级大语言模型&#xff0c;天工大模型通过自然语言与用户进行问答式交互&#xff0c;AI生…...

【机器学习300问】109、什么是岭回归模型?

在进行回归任务时间&#xff0c;可以能会遇到特征数量多于观测数量或某些特征变量之间相关性较高&#xff08;几乎线性相关&#xff09;时&#xff0c;标准的线性回归模型的系数估计可能非常不精确&#xff0c;可以理解成独立方程个数小于未知数个数此时方程有无穷多解。 例如&…...

FJSP:烟花算法(FWA)求解柔性作业车间调度问题(FJSP),提供MATLAB代码

一、烟花算法介绍 参考文献&#xff1a; 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 中&#xff0c;允许使用 {} 对数组进行初始化。 int arr[3] { 0, 1, 2 };C11 扩大了 {} 初始化 的使用范围&#xff0c;使其可用于所有内置类型和自定义类型。 struct Date {int _year;int _month;int _day;Date(int year, int month, int day):_year(year…...

Python3 笔记:字符串的 startswith() 和 endswith()

1、startswith() 方法用于检查字符串是否是以指定子字符串开头&#xff0c;如果是则返回 True&#xff0c;否则返回 False。如果参数 beg 和 end 指定了值&#xff0c;则在指定范围内检查。 语法&#xff1a;str.startswith(substr, beg0,endlen(string)) 参数&#xff1a; s…...

Web前端安全问题分类综合以及XSS、CSRF、SQL注入、DoS/DDoS攻击、会话劫持、点击劫持等详解,增强生产安全意识

前端安全问题是指发生在浏览器、单页面应用、Web页面等前端环境中的各类安全隐患。Web前端作为与用户直接交互的界面&#xff0c;其安全性问题直接关系到用户体验和数据安全。近年来&#xff0c;随着前端技术的快速发展&#xff0c;Web前端安全问题也日益凸显。因此&#xff0c…...

1.单选题 (2分)下列关于脚本的说法不正确的是( )。本题得分: 2分正确答案: A2.单选题 (2分)软件测试自动化的局限性不包含( )。本题得分: 2分

1.单选题 (2分) 下列关于脚本的说法不正确的是( )。 A 线性脚本是最复杂的脚本 B 结构化脚本具有较好的可读性、可重用性,易于维护 C 关键字驱动脚本在开发时,不关心基础函数,直接使用已定义好的关键字 D 数据驱动脚本将测试脚本和数据进行分离,同一个脚本可以针对不同的输…...

【Docker系列】跨平台 Docker 镜像构建:深入理解`--platform`参数

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐: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使用要求 操作系统&#xff1a; Mac OS X 10.9&#xff0c; Ubuntu 14.04显卡&#xff1a;DX9&#xff08;着色器型号 3.0&#xff09;或 DX11&#xff0c;功能级别为 9.3。CPU&#xff1a;支持 SSE2 指令集。Python 2.7 或 Python 3.5Linux 用户…...

在Nginx中配置php程序环境。

1、前言。   我一开始是想 搭建 Tomcat PHP 环境。   Tomcat并不能直接运行PHP&#xff0c;因为Tomcat是一个Java Web服务器&#xff0c;主要用于运行Java应用程序。但是&#xff0c;我们可以通过一些配置和工具来使Tomcat能够运行PHP。   在配置Tomcat支持PHP 项目的时…...

!力扣70. 爬楼梯

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢&#xff1f; 1. 递归&#xff08;超时&#xff09; 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中&#xff0c;将列表转换为字符串有多种方法&#xff0c;最常用的是使用str.join()方法。这里有一些示例&#xff1a; 使用str.join()方法 这是将列表转换为字符串的最直接和最常用的方法。你需要确保列表中的所有元素都是字符串类型…...

二分【1】二分查找框架 查找指定元素

目录 二分查找 基本思想 几种情况汇总 一。严格递增序列 1.查找本身 2.查找第一个大于等于自己的 3.查找第一个大于自己的 4.严格递减序列 二。有重复元素 1.取其中第一个出现的 2.取其中最后一个出现的 二分查找 基本思想 几种情况汇总 一。严格递增序列 1.查找本身…...

Python 中如何使用 lambda 函数

在 Python 中&#xff0c;可以使用 lambda 函数来创建匿名函数。lambda 函数的语法是&#xff1a;lambda 参数: 表达式。以下是一些使用 lambda 函数的例子&#xff1a; 通过 lambda 函数来计算两个数的和&#xff1a; add lambda x, y: x y print(add(2, 3)) # 输出 5通过…...

NFT模式:数字资产确权与链游经济系统构建

NFT模式&#xff1a;数字资产确权与链游经济系统构建 ——从技术架构到可持续生态的范式革命 一、确权技术革新&#xff1a;构建可信数字资产基石 1. 区块链底层架构的进化 跨链互操作协议&#xff1a;基于LayerZero协议实现以太坊、Solana等公链资产互通&#xff0c;通过零知…...

多模态大语言模型arxiv论文略读(108)

CROME: Cross-Modal Adapters for Efficient Multimodal LLM ➡️ 论文标题&#xff1a;CROME: Cross-Modal Adapters for Efficient Multimodal LLM ➡️ 论文作者&#xff1a;Sayna Ebrahimi, Sercan O. Arik, Tejas Nama, Tomas Pfister ➡️ 研究机构: Google Cloud AI Re…...

[Java恶补day16] 238.除自身以外数组的乘积

给你一个整数数组 nums&#xff0c;返回 数组 answer &#xff0c;其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。 请 不要使用除法&#xff0c;且在 O(n) 时间复杂度…...

tree 树组件大数据卡顿问题优化

问题背景 项目中有用到树组件用来做文件目录&#xff0c;但是由于这个树组件的节点越来越多&#xff0c;导致页面在滚动这个树组件的时候浏览器就很容易卡死。这种问题基本上都是因为dom节点太多&#xff0c;导致的浏览器卡顿&#xff0c;这里很明显就需要用到虚拟列表的技术&…...

sipsak:SIP瑞士军刀!全参数详细教程!Kali Linux教程!

简介 sipsak 是一个面向会话初始协议 (SIP) 应用程序开发人员和管理员的小型命令行工具。它可以用于对 SIP 应用程序和设备进行一些简单的测试。 sipsak 是一款 SIP 压力和诊断实用程序。它通过 sip-uri 向服务器发送 SIP 请求&#xff0c;并检查收到的响应。它以以下模式之一…...

08. C#入门系列【类的基本概念】:开启编程世界的奇妙冒险

C#入门系列【类的基本概念】&#xff1a;开启编程世界的奇妙冒险 嘿&#xff0c;各位编程小白探险家&#xff01;欢迎来到 C# 的奇幻大陆&#xff01;今天咱们要深入探索这片大陆上至关重要的 “建筑”—— 类&#xff01;别害怕&#xff0c;跟着我&#xff0c;保准让你轻松搞…...

NPOI操作EXCEL文件 ——CAD C# 二次开发

缺点:dll.版本容易加载错误。CAD加载插件时&#xff0c;没有加载所有类库。插件运行过程中用到某个类库&#xff0c;会从CAD的安装目录找&#xff0c;找不到就报错了。 【方案2】让CAD在加载过程中把类库加载到内存 【方案3】是发现缺少了哪个库&#xff0c;就用插件程序加载进…...

LOOI机器人的技术实现解析:从手势识别到边缘检测

LOOI机器人作为一款创新的AI硬件产品&#xff0c;通过将智能手机转变为具有情感交互能力的桌面机器人&#xff0c;展示了前沿AI技术与传统硬件设计的完美结合。作为AI与玩具领域的专家&#xff0c;我将全面解析LOOI的技术实现架构&#xff0c;特别是其手势识别、物体识别和环境…...

WebRTC调研

WebRTC是什么&#xff0c;为什么&#xff0c;如何使用 WebRTC有什么优势 WebRTC Architecture Amazon KVS WebRTC 其它厂商WebRTC 海康门禁WebRTC 海康门禁其他界面整理 威视通WebRTC 局域网 Google浏览器 Microsoft Edge 公网 RTSP RTMP NVR ONVIF SIP SRT WebRTC协…...

高效的后台管理系统——可进行二次开发

随着互联网技术的迅猛发展&#xff0c;企业的数字化管理变得愈加重要。后台管理系统作为数据存储与业务管理的核心&#xff0c;成为了现代企业不可或缺的一部分。今天我们要介绍的是一款名为 若依后台管理框架 的系统&#xff0c;它不仅支持跨平台应用&#xff0c;还能提供丰富…...