Codeforces Round 949 (Div. 2) A~D

A. Turtle and Piggy Are Playing a Game (思维)

题意:

给出一个整数 x x x ,使得 l ≤ x ≤ r l \le x \le r lxr ,其中 l , r l, r l,r 为给定值。同时保证 2 l ≤ r 2l \le r 2lr
执行以下操作,直到 x x x 变为 1 1 1

  • 选择一个整数 p p p ,使得 p ≥ 2 p \ge 2 p2 p ∣ x p \mid x px (即 x x x p p p 的倍数)。
  • x x x 设置为 x p \frac{x}{p} px ,得分将增加 1 1 1

得分最初为 0 0 0 。询问得分最大为多少。

分析:

2 2 2的增长速度是最慢的,并且题目有 2 × l ≤ r 2 \times l \le r 2×lr,所以答案为 l o g 2 r log_2r log2r向下取整。

代码:

#include <bits/stdc++.h>

using namespace std;

int main() {
    int t;
    cin >> t;
    while (t--) {
        int l, r;
        cin >> l >> r;
        int ans = __lg(r);
        cout << ans << endl;
    }
    return 0;
}

B.Turtle and an Infinite Sequence (位运算)

题意:

给出一个无限长的序列 a 0 , a 1 , a 2 , … a_0, a_1, a_2, \ldots a0,a1,a2, 。对于每个非负整数 i i i ,初始值为 a i = i a_i = i ai=i
每一秒之后,序列中的每个元素都会同时发生变化。对于每个正整数 i i i a i a_i ai 将变为 a i − 1 ∣ a i ∣ a i + 1 a_{i - 1} \mid a_i \mid a_{i + 1} ai1aiai+1 a 0 a_0 a0 将变为 a 0 ∣ a 1 a_0 \mid a_1 a0a1
给出 m m m,询问 m m m秒之后, a n a_n an的值。

分析:

发现 a n a_n an m m m秒之后的答案为 [ n − m , n + m ] [n-m,n+m] [nm,n+m]这个区间里面所有数的异或和。我们直接枚举答案的二进制位 i i i,判断 i i i能否变成 1 1 1。只需找到第一个 x x x,满足 x ≥ l , x ≤ r , x > > i x \ge l, x \le r, x>>i xl,xr,x>>i & 1 1 1即可。

代码:

#include <bits/stdc++.h>

using namespace std;
typedef long long LL;

int main() {
    int t;
    cin >> t;
    while (t--) {
        LL n, m;
        cin >> n >> m;
        LL l = max(0LL, n - m);
        LL r = n + m;
        LL ans = 0;
        LL cnt = 0;
        while (l != r) {
            cnt++;
            l >>= 1;
            r >>= 1;
        }
        while (cnt--)
            r = (r << 1) ^ 1;
        cout << r << endl;
    }
    return 0;
}

C.Turtle and an Incomplete Sequence (位运算)

题意:

给出一个正整数组成的序列 a 1 , a 2 , … , a n a_1, a_2, \ldots, a_n a1,a2,,an但是现在序列不完整了。可能存在任意数量的索引 i i i ,使得 a i a_i ai 变成 − 1 -1 1 。让新序列为 a ′ a' a。保证对于原始序列 a a a ,要么 a i = ⌊ a i + 1 2 ⌋ a_i = \left\lfloor\frac{a_{i + 1}}{2}\right\rfloor ai=2ai+1 成立,要么 a i + 1 = ⌊ a i 2 ⌋ a_{i + 1} = \left\lfloor\frac{a_i}{2}\right\rfloor ai+1=2ai 成立。

换句话说,你需要找到另一个由正整数组成的序列 b 1 , b 2 , … , b n b_1, b_2, \ldots, b_n b1,b2,,bn ,并且:

  • 对于从 1 1 1 n n n 的每个整数 i i i ,如果 a i ′ ≠ − 1 a'_i \ne -1 ai=1 ,则 b i = a i ′ b_i = a'_i bi=ai
  • 对于从 1 1 1 n − 1 n - 1 n1 的每个整数 i i i b i = ⌊ b i + 1 2 ⌋ b_i = \left\lfloor\frac{b_{i + 1}}{2}\right\rfloor bi=2bi+1 b i + 1 = ⌊ b i 2 ⌋ b_{i + 1} = \left\lfloor\frac{b_i}{2}\right\rfloor bi+1=2bi 成立。
  • 对于从 1 1 1 n n n 的每个整数 i i i 1 ≤ b i ≤ 1 0 9 1 \le b_i \le 10^9 1bi109

如果没有满足上述所有条件的序列 b 1 , b 2 , … , b n b_1, b_2, \ldots, b_n b1,b2,,bn ,则需要输出 − 1 -1 1

分析:

我们考虑将操作统一,即满足 b i = b i − 1 / 2 b_i=b_{i-1}/2 bi=bi1/2 或者满足 b i = b i − 1 × 2 b_i=b_{i-1} \times 2 bi=bi1×2 或者 b i = b i − 1 × 2 + 1 b_i=b_{i-1} \times 2+1 bi=bi1×2+1,并将操作转换成在二进制上考虑是将前一个数右移一位还是在末尾填上 0 0 0或者 1 1 1
我们接下来考虑从 x x x变成 y y y至少需要多少个操作,首先求出 x x x, y y y 的二进制最长公共前缀,然后将 x x x通过右移操作变成其最长公共前缀,然后再通过填 1 1 1或者填 0 0 0来变成 y y y。最后剩余的数通过反复乘 2 2 2或者除 2 2 2操作即可。

代码:

#include <bits/stdc++.h>

using namespace std;
typedef long long LL;
const LL N = 5e5 + 10;
const LL mod = 1e9 + 7;

LL gcd(LL a, LL b) {
    return b > 0 ? gcd(b, a % b) : a;
}

int a[N];

void solve() {
    int n;
    cin >> n;
    int bit[n + 5][32];
    for (int i = 1; i <= n; i++)
        cin >> a[i];
    vector<int> pos;
    int st = 0, en = 0;
    for (int i = 1; i <= n; i++) {
        if (a[i] != -1) {
            if (!st)
                st = i;
            pos.push_back(i);
            for (int j = 0; j < 32; j++) {
                bit[i][j] = ((a[i] >> j) & 1);
            }
            en = i;
        }
    }
    int f = 0;
    for (int i = st - 1; i >= 1; i--) {
        if (f == 0) {
            a[i] = a[i + 1] * 2;
        } else {
            a[i] = a[i + 1] / 2;
        }
        f ^= 1;
    }
    f = 0;
    for (int i = en + 1; i <= n; i++) {
        if (i == 1) {
            a[i] = 2;
            continue;
        }
        if (f == 0) {
            a[i] = a[i - 1] * 2;
        } else {
            a[i] = a[i - 1] / 2;
        }
        f ^= 1;
    }
    int len = pos.size();
    for (int i = 0; i < len - 1; i++) {
        int l = a[pos[i]], r = a[pos[i + 1]];
        int tmp = l;
        int len1 = 0, len2 = 0;
        while (tmp) {
            tmp /= 2;
            len1++;
        }
        tmp = r;
        while (tmp) {
            tmp /= 2;
            len2++;
        }
        int tot = 0;
        for (int j = 0; j < min(len1, len2); j++) {
            if (bit[pos[i]][len1 - j - 1] == bit[pos[i + 1]][len2 - j - 1])
                tot++;
            else
                break;
        }
        int num = len1 + len2 - 2 * tot;
        if (pos[i + 1] - pos[i] < num || (pos[i + 1] - pos[i] - num) % 2 != 0) {
            cout << -1 << endl;
            return;
        }
        int num1 = len1 - tot;
        int num2 = len2 - tot;
        int po = pos[i] + 1;
        for (int j = 0; j < num1; j++) {
            a[po] = a[po - 1] / 2;
            po++;
        }
        for (int j = 0; j < num2; j++) {
            if (bit[pos[i + 1]][len2 - tot - j - 1] == 0) {
                a[po] = a[po - 1] * 2;
            } else {
                a[po] = a[po - 1] * 2 + 1;
            }
            po++;
        }
        int f = 1;
        for (po; po < pos[i + 1]; po++) {
            if (f == 1) {
                a[po] = a[po - 1] * 2;
            } else {
                a[po] = a[po - 1] / 2;
            }
            f ^= 1;
        }
    }
    for (int i = 1; i <= n; i++) {
        cout << a[i] << " ";
    }
    cout << endl;
}

int main() {
    int t = 1;
    cin >> t;
    while (t--) {
        solve();
    }
    return 0;
}

D.Turtle and Multiplication (图论)

题意:

给一个整数 n n n ,并要求构造一个由满足以下条件的整数组成的序列 a 1 , a 2 , … , a n a_1, a_2, \ldots, a_n a1,a2,,an

  • 对于所有 1 ≤ i ≤ n 1 \le i \le n 1in 1 ≤ a i ≤ 3 ⋅ 1 0 5 1 \le a_i \le 3 \cdot 10^5 1ai3105
  • 对于所有 1 ≤ i ≤ j ≤ n − 1 1 \le i \le j \le n - 1 1ijn1 a i ⋅ a i + 1 ≠ a j ⋅ a j + 1 a_i \cdot a_{i + 1} \ne a_j \cdot a_{j + 1} aiai+1=ajaj+1

在所有这些序列中,找出具有最少个不同元素的序列。

分析:

如果我们都选质数,那么两对之间乘积不相同也就等价于两对质数不完全相同。那么将问题转化为在一个完全图上找欧拉路。如果我们只用奇数个质数,那么每个点度是偶数,有欧拉回路。如果用偶数个质数,就要删掉质数数量的一半减一条边,这样才会产生只有两个奇数度的点。

代码:

#include <bits/stdc++.h>

using namespace std;
typedef long long LL;
const LL N = 3e5 + 10;
const LL mod = 1e9 + 7;
int n, m, st[N], g[1510][1510];
vector<int> pri;
stack<int> stk;

void dfs(int u) {
    if (g[u][u])
        g[u][u] = 0, dfs(u);
    for (int i = 1; i <= m; i++)
        if (g[u][i])
            g[u][i] = g[i][u] = 0, dfs(i);
    stk.push(pri[u]);
}

int main() {
    for (int i = 2; i <= 300000; i++) {
        if (!st[i])
            pri.push_back(i);
        for (int j = i * 2; j <= 300000; j += i)
            st[j] = 1;
    }
    int T;
    cin >> T;
    while (T--) {
        cin >> n;
        if (n == 1) {
            cout << 1 << endl;
            continue;
        }
        m = 1;
        while (m * (m + 1) / 2 - (m % 2 ? 0 : m / 2 - 1) < n - 1)
            m++;
        for (int i = 1; i <= m; i++)
            for (int j = 1; j <= m; j++)
                g[i][j] = 1;
        if (m % 2 == 0)
            for (int i = 3; i <= m; i += 2)
                g[i][i + 1] = g[i + 1][i] = 0;
        dfs(1);
        while (stk.size() && n) {
            cout << stk.top() << " ";
            stk.pop();
            n--;
        }
        while (stk.size())
            stk.pop();
        cout << endl;
    }
    return 0;
}

赛后交流

在比赛结束后,会在交流群中给出比赛题解,同学们可以在赛后查看题解进行补题。

群号: 704572101,赛后大家可以一起交流做题思路,分享做题技巧,欢迎大家的加入。

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

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

相关文章

【C51】C51单片机实现的 抽奖机 设计与编程指南

文章目录 前言&#xff1a;1. 实现效果2. 准备工作3. 编写代码总结&#xff1a; 前言&#xff1a; 在本文中&#xff0c;我们将介绍如何使用C51单片机来实现一个简单的抽奖机。这个项目不仅能够展示C51单片机的基本应用&#xff0c;还能让我们了解如何通过编程来控制硬件&…

Unity协程学习心得

前言 个人总结的一些Unity协程学习心得&#xff0c;如有不对请在评论区指出一起学习&#xff01;感谢。 在Unity编程中谈到异步逻辑&#xff0c;可以考虑使用协程来实现。协程&#xff08;Coroutine&#xff09;在Unity中的主要作用就是把一个任务暂停&#xff08;挂起&#…

Java集合汇总

Java中的集合框架是Java语言的核心部分&#xff0c;提供了强大的数据结构来存储和操作对象集合。集合框架位于java.util包中&#xff0c;主要可以分为两大类&#xff1a;Collection&#xff08;单列集合&#xff09;和Map&#xff08;双列集合&#xff09;。下面是对它们的总结…

NXP i.MX8系列平台开发讲解 - 3.14 Linux 之Power Supply子系统(二)

专栏文章目录传送门&#xff1a;返回专栏目录 Hi, 我是你们的老朋友&#xff0c;主要专注于嵌入式软件开发&#xff0c;有兴趣不要忘记点击关注【码思途远】 目录 1. 前言 2. 芯片简介 2. 系统原理设计 2. 设备树相关 本文实操是基于Android11 系统下i.MX8MQ环境下&#x…

博睿数据应邀出席双态IT用户大会,分享《构建云原生时代的一体化智能可观测性》

5月31日-6月2日&#xff0c;第十二届双态IT用户大会于成都成功举行&#xff0c;此次大会由DCMG和双态IT论坛联合主办&#xff0c;聚焦“信创时代的组织级云原生能力建设”和“组织级云原生运维能力建设”两大会议主题&#xff0c;旨在推动双态IT落地与创新&#xff0c;为企业数…

LabVIEW在高校中的应用

LabVIEW 作为一款功能强大的图形化编程工具&#xff0c;在高校中有广泛的应用。它不仅用于教学实验&#xff0c;还广泛应用于科研项目和工程训练。本文将从教学、科研、实验室管理和学生技能培养等多个角度&#xff0c;详细分析LabVIEW在高校中的应用。 教学应用 课程设计 自动…

快来速领限量免费亚马逊云科技助理级架构师(SAA)和云从业者50%半价考试券

前几天在上海5/29的亚马逊云科技Summit峰会里&#xff0c;小李哥在现场分享了AWS 13张认证大满贯的心得&#xff08;图1&#xff09;&#xff0c;并且现场招募了自己的云师兄必过班(图2)。 本次必过班也为成员发放AWS SAA(助理级架构师)和云从业者(Cloud Practitioner)50%考试券…

华为防火墙配置 SSL VPN

前言 哈喽&#xff0c;我是ICT大龙。本期给大家更新一次使用华为防火墙实现SSL VPN的技术文章。 本次实验只需要用到两个软件&#xff0c;分别是ENSP和VMware&#xff0c;本次实验中的所有文件都可以在文章的末尾获取。话不多说&#xff0c;教程开始。 什么是VPN 百度百科解…

未在本地计算机上注册“Microsoft.ACE.OLEDB.12.0”提供程序。.net 读取excel的时候报错(实测有效)

1. 下载AccessDatabaseEngine.exe 下载链接 添加链接描述 2. office excel是64为的需要安装【AccessDatabaseEngine.exe】、32位的【AccessDatabaseEngine_X64.exe】 3. 我的是64为&#xff0c;跳过32位安装检测 1. 找到下载的安装包 2.输入安装包文件全称并在后面加上/pas…

C++之RTTI

1、RTTI&#xff08;runtime type information&#xff09;运行时类型信息 static_cast&#xff1a;用在编译器认可的转型 reinterpret_cast&#xff1a;用在编译器不认可的转型&#xff08;不做任何的对齐操作&#xff09; const_cast&#xff1a;去除常量属性 dynamic_ca…

Java 泛型类,泛型方法,泛型接口和通配符(用来限定类和方法的使用范围)

测试类 package Genericity;import java.util.ArrayList;public class test {public static void main(String[] args) {// 使用泛型方法添加元素ArrayList<String> list new ArrayList<>();MyToolClass.ListAdd(list,"fdsf","dsfa");System…

Triton学习笔记

b站链接&#xff1a;合集Triton 从入门到精通 文章目录 算法名词解释&#xff1a;scheduler 任务调度器model instance、inference和requestbatching 一、Triton Inference Server原理1. Overview of Trition2. Design Basics of Trition3. Auxiliary Features of Trition4. A…

C++笔试强训day42

目录 1.最大差值 2.兑换零钱 3.小红的子串 1.最大差值 链接https://www.nowcoder.com/practice/a01abbdc52ba4d5f8777fb5dae91b204?tpId182&tqId34396&rp1&ru/exam/company&qru/exam/company&sourceUrl%2Fexam%2Fcompany&difficulty2&judgeSta…

6.9总结

Vue生命周期 生命周期&#xff1a;指一个对象从创建到销毁的整个过程生命周期的八个阶段&#xff1a;每触发一个生命周期事件&#xff0c;会自动执行一个生命周期的方法&#xff08;钩子&#xff09; mounted&#xff1a;挂载完成&#xff0c;Vue初始化成功&#xff0c;HTML渲…

JAVA小案例-递归:计算n!

JAVA小案例-递归&#xff1a;计算n! 首先抛出概念&#xff0c;什么是递归&#xff1f; 说白了就是自己调用自己。 递归的结构&#xff1a; &#xff08;1&#xff09;递归头&#xff1a;就是什么时候不调用自身的方法&#xff0c;也就是递归结束的条件 &#xff08;2&#xff…

轴承接触角和受力分析

提示&#xff1a;轴承接触角和受力分析 文章目录 1&#xff0c;接触角2&#xff0c;轴承受力分析 1&#xff0c;接触角 所谓公称接触角就是指轴承在正常状态下&#xff0c; 滚动体和内圈及外圈沟道接触点的法线与轴心线的垂直平面之间的夹角。 按滚动轴承工作时所能承受载荷的…

AI大模型学习(非常详细)零基础入门到精通,收藏这一篇就够了

前言 随着人工智能技术的快速发展&#xff0c;AI大模型学习正成为一项备受关注的研究领域。为了提高模型的准确性和效率&#xff0c;研究者们需要具备深厚的数学基础和编程能力&#xff0c;并对特定领域的业务场景有深入的了解。通过不断优化模型结构和算法&#xff0c;AI大模…

Nginx部署多web进程

1、nginx介绍 Nginx是一个高性能的、开源的、跨平台的Web服务器和反向代理服务器。它是由俄罗斯的程序员Igor Sysoev开发的&#xff0c;并于2004年首次公开发布。 Nginx的特点包括&#xff1a; 高性能&#xff1a;Nginx使用事件驱动的架构&#xff0c;能够处理大量的并发连接…

GAT1399协议分析(9)--图像上传

一、官方定义 二、wirechark实例 有前面查询的基础,这个接口相对简单很多。 请求: 文本化: POST /VIID/Images HTTP/1.1 Host: 10.0.201.56:31400 User-Agent: python-requests/2.32.3 Accept-Encoding: gzip, deflate Accept: */* Connection: keep-alive content-type:…

基于睡眠声音评估睡眠质量

随着健康意识的增强&#xff0c;人们越来越关注睡眠质量。确保获得充足的高质量睡眠对于维持身体健康和心理平衡至关重要。专业的睡眠状态测量主要通过多导睡眠图&#xff08;PSG&#xff09;进行。然而&#xff0c;PSG会给受试者带来显著的身体负担&#xff0c;并且在没有专业…