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:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/688098.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

大小堆运用巧解数据流的中位数

​​​​​​​​​​ 一、思路 我们将所有数据平分成两份&#xff0c;前面那一部分用小堆来存&#xff0c;后面的部分用大堆来存&#xff0c;这样我们就能立刻拿到中间位置的值。 如果是奇数个数字&#xff0c;那么我们就将把中间值放在前面的大堆里&#xff0c;所以会有两种…

华为设备动态路由OSPF(单区域+多区域)实验

动态路由OSPF的配置 OSPF分类两种情况&#xff1a;单区域 多区域路由 OSPF单区域路由配置 OSPF&#xff1a;开放最短路径优先的路由协议。属于大型动态路由协议&#xff0c;适用于中大型的园区网。 网络拓扑&#xff1a; 配置步骤&#xff1a; 1.完成基本配置&#xff08;略&a…

代码随想录算法训练营第30天|回溯复习篇

回溯基础理论 1.回溯的本质是利用递归进行暴力搜索&#xff0c;将符和条件的结果集搜索出来 2.回溯法常见的问题&#xff1a; 组合问题&#xff1a;N个数里面按一定规则找出k个数的集合排列问题&#xff1a;N个数按一定规则全排列&#xff0c;有几种排列方式切割问题&#x…

fastadmin/thinkPHPQueue消息队列详细教程

thinkphp-queue 是thinkphp 官方提供的一个消息队列服务,它支持消息队列的一些基本特性: 消息的发布,获取,执行,删除,重发,失败处理,延迟执行,超时控制等队列的多队列, 内存限制 ,启动,停止,守护等消息队列可降级为同步执行1、通过composer安装thinkPHP消息队列 …

kafka-消费者-指定offset消费(SpringBoot整合Kafka)

文章目录 1、指定offset消费1.1、创建消费者监听器‘1.2、application.yml配置1.3、使用 Java代码 创建 主题 my_topic1 并建立3个分区并给每个分区建立3个副本1.4、创建生产者发送消息1.4.1、分区0中的数据 1.5、创建SpringBoot启动类1.6、屏蔽 kafka debug 日志 logback.xml1…

算法003:快乐数

这道题采用快慢双指针的方法。 为了弄清楚这个题到底是要我们干嘛&#xff0c;我们把整个过程类比一下&#xff1a; 不管是n19还是n2&#xff0c;我们都把它当成一种判断链表是否有环的方式。 对于n19&#xff0c;题干是这样解释的&#xff1a; 我们把它当成链表&#xff0c…

如何挑选最适合你的渲染工具

随着技术的发展&#xff0c;云渲染平台逐渐成为设计师、动画师、影视制作人员等创意工作者的得力助手。然而&#xff0c;市场上的云渲染平台种类繁多&#xff0c;如何选择最适合自己的渲染工具成为了一个需要认真考虑的问题。 在挑选适合自己的云渲染工具时&#xff0c;我们需…

YOLOv10涨点改进:原创自研 | GhostNet融合 | 从廉价的操作中生成更多的特征图

文章目录 GhostNet理论基础实验部分改进方案新增yolov10s-ghost.yaml文件代码运行GhostNet理论基础 Ghost Module是一种模型压缩的方法,即在保证网络精度的同时减少网络参数和计算量,从而提升计算速度(speed),降低延时(latency)。Ghost 模块可以代替现有卷积网络中的每…

OpenAI模型规范概览

这是OpenAI对外分享的模型规范文档&#xff08;Model Spec&#xff09;&#xff0c;它定义了OpenAI希望在API接口和ChatGPT&#xff08;含GPT系列产品&#xff09;中模型的行为方式&#xff0c;这也是OpenAI超级对齐团队奉行的行为准则&#xff0c;希望能对国内做RLHF的同学有帮…

.Net实现SCrypt Hash加密

方案1 &#xff08;加密后存储“算法设置”、“盐(随机值)”、“Hash值”&#xff0c;以“$”分隔&#xff09;&#xff1a; //Nuget引入SCrypt.NET库 using Org.BouncyCastle.Crypto.Generators; using Scrypt; using System; using System.Security.Cryptography; namespace …

Apache OFBiz 路径遍历导致RCE漏洞复现(CVE-2024-36104)

0x01 产品简介 Apache OFBiz是一个电子商务平台,用于构建大中型企业级、跨平台、跨数据库、跨应用服务器的多层、分布式电子商务类应用系统。是美国阿帕奇(Apache)基金会的一套企业资源计划(ERP)系统。该系统提供了一整套基于Java的Web应用程序组件和工具。 0x02 漏洞概…

90后机器人创业者再获10亿元融资,为精密传动行业注入新动力!

据了解&#xff0c;一位90后机器人创业者再次获得近10亿元人民币的融资&#xff0c;这一消息在精密传动行业引起了广泛关注。 杭州宇树科技有限公司&#xff08;简称“宇树”&#xff09;&#xff0c;2024年春节前完成了B2轮融资&#xff0c;融资近10亿元人民币&#xff0c;本轮…

pyqt5 tablewidget实现excel拖曳填充

代码主要涉及鼠标事件和绘图&#xff0c;selectionModel&#xff0c;selectedIndexes。 import sys from PyQt5.QtCore import QPoint, Qt, QCoreApplication, pyqtSlot from PyQt5.QtGui import QBrush, QPixmap, QColor, QPainter,QIcon,QPolygon from PyQt5.QtWidgets imp…

【Java】解决Java报错:ClassCastException

文章目录 引言1. 错误详解2. 常见的出错场景2.1 错误的类型转换2.2 泛型集合中的类型转换2.3 自定义类和接口转换 3. 解决方案3.1 使用 instanceof 检查类型3.2 使用泛型3.3 避免不必要的类型转换 4. 预防措施4.1 使用泛型和注解4.2 编写防御性代码4.3 使用注解和检查工具 5. 示…

64. UE5 RPG 创建新的双手攻击怪物

在上一篇文章中&#xff0c;我们实现了新的功能&#xff0c;现在可以创建多个普通攻击动画&#xff0c;并且可以根据你所使用的普通攻击动画&#xff0c;设置不同的攻击位置。比如&#xff0c;你使用武器&#xff0c;那么攻击位置需要从武器上获取&#xff0c;如果你没有持有武…

《精通ChatGPT:从入门到大师的Prompt指南》第2章:Prompt的基本概念

2.1 什么是Prompt 在了解和使用ChatGPT的过程中&#xff0c;理解和掌握Prompt的概念是至关重要的。Prompt可以简单地定义为一段指令或请求&#xff0c;它向AI模型提供了生成特定回应或行为所需的初始信息。具体而言&#xff0c;Prompt是用户与AI系统之间的桥梁&#xff0c;通过…

MatrixOne→MatrixOS:矩阵起源的创业史即将用“AI Infra”和“AI Platform”书写新章程

在数字化浪潮的推动下&#xff0c;MatrixOne的故事就像一部科技界的创业史诗&#xff0c;它始于一个简单而宏伟的梦想——构建一个能够支撑起新一代数字世界的操作系统。想象一下&#xff0c;在AIGC时代&#xff0c;数据流动如同“血液”&#xff0c;算法运转如同“心跳”&…

【Neo4j】Windows11使用Neo4j导入CSV数据可视化知识图谱

Windows11使用Neo4j导入CSV数据可视化知识图谱 序1. 安装JDK21&#xff08;1&#xff09;下载&#xff08;2&#xff09;安装&#xff08;3&#xff09;环境配置 2. 安装Neo4j&#xff08;1&#xff09;下载&#xff08;2&#xff09;解压安装&#xff08;3&#xff09;环境配置…

国货美妆品牌站上C位,抖音618大促期间相关产品销量同比增长53%

每年618大促时期是各类美妆产品销售旺季。近两年&#xff0c;爱美人士的囤货清单里出现越来越多国货美妆品牌。 据《2023年中国化妆品年鉴》&#xff0c;去年国内美妆市场总体规模达7972亿元&#xff0c;其中&#xff0c;国货市场份额达到50.4%&#xff0c;首次超越外资品牌。…

Cloudpods 强大的多云管理平台部署

简介 Cloudpods 是一款简单、可靠的企业IaaS资源管理软件。帮助未云化企业全面云化IDC物理资源&#xff0c;提升企业IT管理效率。 Cloudpods 帮助客户在一个地方管理所有云计算资源。统一管理异构IT基础设施资源&#xff0c;极大简化多云架构复杂度和难度&#xff0c;帮助企业…