牛客练习赛123 A~C

news2025/1/24 22:37:07

A.炸鸡块哥哥的粉丝题

输出字符串的前 ⌈ n 2 ⌉ \lceil \frac{n}{2} \rceil 2n 个字符

void solve()
{
    int n;
    string s;
    cin >> n >> s;
    cout << s.substr(0, (n + 1) / 2);
}

B.智乃想考一道鸽巢原理

当小球总个数为奇数时,贪心的留下 1 个小球,反之,留下 2 个小球,我们将这个值定义为 P ,即该颜色小球最小留下的个数。
常见的此类问题,我们只需要得到最大值,之后判断 t o t ≤ M a x { a i } × 2 tot\le Max\{a_i\} \times 2 totMax{ai}×2 即可判断这个球是否会留下,但是这个题要求判断每一个小球是否能留下,要解决这个问题需要额外记录一个次大值即可解决。

void solve()
{
    ll n, mx = 0, sx = 0, tot = 0;
    ll p=1;
    cin >> n;
    vector<ll> a(n);
    for (ll &i : a)
    {
        cin >> i;
        tot += i;
        if (i >= mx)
        {
            sx = max(sx, mx);
            mx = i;
        }
        else
            sx = max(i, sx);
    }
    if(tot%2==0)
        p=2;
    for (int i = 0; i < n; i++)
    {
        if(a[i]<p)
            cout<< "0";
        else if ((a[i] == mx && (tot - p) >= sx * 2) || (tot - p) >= mx * 2)
            cout << "1";
        else
            cout << "0";
        cout << " \n"[i == n - 1];
    }
}

C.智乃想考一道完全背包(Easy version)

首先我们注意到题目的要求
a 1 ≤ a 2 ≤ . . . ≤ a k ≥ a k + 1 ≥ . . . ≥ a n a_1 \le a_2\le...\le a_k\ge a_{k+1} \ge ... \ge a_n a1a2...akak+1...an
由这个限制条件我们很容易想到的是,当我们选取一个 K 以左的物品 a i a_i ai 时,我们必须保证 i → k i \to k ik 这一段物品依次选取过一次,那么我们就可以对背包物品的体积和价值预处理一下。

 for (int i = k - 1; i >= 1; i--)
    {
        w[i] += w[i + 1];
        v[i] += v[i + 1];
    }
    for (int i = k + 1; i <= n; i++)
    {
        w[i] += w[i - 1];
        v[i] += v[i - 1];
    }

然而当我们这样处理时,会导致第 K 个物品可能出现多余取的情况,如下图
在这里插入图片描述
为了解决这种情况,我们把这 N 个已被组合的区间互相组合一下,易证,最多会有 62500 个物品存在( M ≤ 500 M \le 500 M500,假定每个物品体积均为 1,最多左右 250 个物品直之间合并),之后对这些物品跑一遍完全背包,时间复杂度为 O ( m 3 4 ) O(\frac{m^3}{4}) O(4m3)

void solve()
{
    ll k, n, m;
    cin >> n >> m >> k;
    vector<ll> v(n + 1), w(n + 1), f(m + 10);
    for (int i = 1; i <= n; i++)
        cin >> w[i] >> v[i];
    for (int i = k - 1; i >= 1; i--)
    {
        w[i] += w[i + 1];
        v[i] += v[i + 1];
    }
    for (int i = k + 1; i <= n; i++)
    {
        w[i] += w[i - 1];
        v[i] += v[i - 1];
    }
    for (int i = 1; i <= k - 1; i++)
    {
        for (int j = k + 1; j <= n; j++)
        {
            if (w[i] + w[j] - w[k] <= m)
            {
                w.push_back(w[i] + w[j] - w[k]);
                v.push_back(v[i] + v[j] - v[k]);
            }
        }
    }
    for (ll i = 1; i < v.size(); i++)
    {
        for (ll j = w[i]; j <= m; j++)
            f[j] = max(f[j], f[j - w[i]] + v[i]);
    }
    for (int i = 1; i <= m; i++)
        cout << f[i] << " \n"[i == m];
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

(C++笔试题)选择题+编程题

个人主页&#xff1a;Lei宝啊 愿所有美好如期而遇 选择题 第一道 下面对析构函数的正确描述是&#xff08;&#xff09; A. 系统不能提供默认的析构函数B. 析构函数必须由用户定义C. 析构函数没有参数D. 析构函数可以设置默认参数 解析&#xff1a; 正确描述析构函数的…

【独立开发前线】Vol.27 为什么独立开发者需要一个网站?

现在很多内容创造者都把主要平台放在了第三方平台上&#xff0c;包括像知乎、B站、头条等等&#xff0c;但即使在2024年&#xff0c;我依然建议你做一个完全属于你的网站。 为什么呢&#xff1f; 你有没有在微信或知乎看到过这种拦截页面&#xff1f; 你花了好大的精力写了一…

关于github提交失败的问题

问题描述 Username for https://github.com: LAL-Better Password for https://LAL-Bettergithub.com: remote: Support for password authentication was removed on August 13, 2021. remote: Please see https://docs.github.com/get-started/getting-started-with-git/abo…

线程的通信

1.需求(为什么需要线程通信) 当我们需要多个线程完成同一任务时&#xff0c;并且希望他们有规律的执行&#xff0c;那么多线程之间需要一些通信机制&#xff0c;并且可以协调他们的工作&#xff0c;以此实现多个线程共同操作共享数据. 例 : A做包子&#xff0c;B吃包子&#…

SAP Fiori开发中的JavaScript基础知识9 - 代码注释,严格模式,JSON

1 背景 本文将介绍JavaScript编程中的三个小知识点&#xff1a;也即代码注释&#xff0c;严格模式&#xff0c;JSON文件。 2 代码注释 JavaScript的代码注释方式如下&#xff1a; // Single line comment/* Multi line comment */3 严格模式 JavaScript的"strict mod…

vue3封装Element表格自适应

表格高度自适应 分页跟随表格之后 1. 满屏时出现滚动条 2. 不满屏时不显示滚动条 坑 表格设置maxHeight后不出现滚动条 解决方案 表格外层元素设置max-height el-table–fit 设置高度100% .table-box {max-height: calc(100% - 120px); } .el-table--fit {height: 100%; }示例代…

rust使用Command库调用cmd命令或者shell命令,并支持多个参数和指定文件夹目录

想要在不同的平台上运行flutter doctor命令&#xff0c;就需要知道对应的平台是windows还是linux&#xff0c;如果是windows就需要调用cmd命令&#xff0c;如果是linux平台&#xff0c;就需要调用sh命令&#xff0c;所以可以通过cfg!实现不同平台的判断&#xff0c;然后调用不同…

[flask]http请求//获取请求头信息+客户端信息

在网站中查询请求头信息&#xff0c;可以通过以下操作进行 右键然后选择检查 进入改页面后选择文档&#xff0c;刷新一下页面就好了 获取所有的请求头信息 print(request.headers, type(request.headers)) 在flask模块中&#xff0c;使用上面的输出函数就可以查看到有关于请求…

鸿蒙OS开发实战:【Socket小试MQTT连接】

本篇分享一下 HarmonyOS 中的Socket使用方法 将从2个方面实践&#xff1a; HarmonyOS 手机应用连接PC端 SocketServerHarmonyOS 手机应用连接MQTT 服务端 通过循序渐进的方式&#xff0c;全面了解实践HarmonyOS中的Socket用法 学习本章前先熟悉文档开发知识更新库gitee.com…

3-zookeeper之ZAB协议

Zookeeper ZAB协议 概述 ZAB(Zookeeper Automic Broadcast)是一套专门为Zookeeper设计的用于进行原子广播和崩溃恢复的协议ZAB协议主要包含了两个功能 原子广播&#xff1a;保证数据一致性崩溃恢复&#xff1a;保证集群的高可用 ZAB协议本身是基于2PC算法来进行的设计&#…

『VUE』05. 条件渲染(详细图文注释)

目录 新建IfDemo.vuev-if 和 v-elsev-if | v-else-if | v-elsev-showv-show 与 v-if 的区别,性能分析总结 欢迎关注 『VUE』 专栏&#xff0c;持续更新中 欢迎关注 『VUE』 专栏&#xff0c;持续更新中 在前文的项目基础上继续~ 新建IfDemo.vue IfDemo.vue内容如下 <scri…

前端-深入探讨网络面试题

第一关 请求-文件、数据、连接 文件类的请求&#xff1a;加载HTMl、CSS 数据&#xff1a; ajax请求&#xff08;基于HTTP&#xff0c;HTTP基于TCP&#xff09;&#xff0c;如何建立连接的&#xff08;三次握手&#xff0c;为什么不是两次或者四次&#xff09;&#xff0c;sock…

用MATLAB编写一个简易的贪吃蛇游戏

编写一个贪吃蛇游戏的MATLAB代码需要涉及到游戏逻辑、图形用户界面(GUI)的创建、事件监听&#xff08;如键盘操作&#xff09;和游戏状态更新等。以下是一个简化的贪吃蛇游戏MATLAB代码示例&#xff0c;展示了基本的游戏框架和逻辑。 此代码创建了一个游戏窗口&#xf…

解决GNU Radio+USRP实现OFDM收发在接收端QPSK星座图映射无“抖动”问题

文章目录 前言一、遇到的问题二、解决方案三、重新编译安装四、验证五、资源自取 前言 本文记录在 GNU RadioUSRP 实现 OFDM 收发时&#xff0c;在接收端 QPSK 星座图映射无“抖动”问题的解决方法&#xff0c; 一、遇到的问题 我遇到的问题是&#xff0c;现在搭建的 OFDM 模…

Qt实现Kermit协议

1 概述 Kermit文件运输协议提供了一条从大型计算机下载文件到微机的途径。它已被用于进行公用数据传输。 其特性如下: Kermit文件运输协议是一个半双工的通信协议。它支持7位ASCII字符。数据以可多达96字节长度的可变长度的分组形式传输。对每个被传送分组需要一个确认。Kerm…

Spark SQL— Catalyst 优化器

Spark SQL— Catalyst 优化器 1. 目的 本文的目标是描述Spark SQL 优化框架以及它如何允许开发人员用很少的代码行表达复杂的查询转换。我们还将描述Spark SQL如何通过大幅提高其查询优化能力来提高查询的执行时间。在本教程中&#xff0c;我们还将介绍什么是优化、为什么使用…

先进电机技术 —— 何为轮毂电机?

一、轮毂电机 轮毂电机&#xff08;Hub Motor&#xff09;是一种将电动机集成到车轮内部&#xff0c;直接驱动车轮转动的电动车驱动技术。这种设计省去了传统的传动轴、差速器、半轴等机械传动部件&#xff0c;使得动力传输更为直接、高效。 轮毂电机的优点&#xff1a; 1. 结…

elementui el-input输入框类型为textarea时,将输入的数据保存换行和空格,并展示换行和空格

el-input输入框类型为textarea时&#xff0c;如果不做数据处理&#xff0c;是不会保存换行和空格的说输入了换行&#xff0c;但是保存数据后不会进行换行&#xff0c;需要保存输入的换行。 1、效果图 输入状态&#xff1a; 显示时&#xff1a; 2、实现代码 2.1、html部分&am…

【CKA模拟题】综合案例演示如何创建pv和pvc

Useful Resources: Persistent Volumes & Claim 题干 For this question, please set this context (In exam, diff cluster name) kubectl config use-context kubernetes-adminkubernetesCreate a PersistentVolume (PV) and a PersistentVolumeClaim (PVC) using an e…

排序---数组和集合

1、数组排序 Arrays.sort(int[] a)这种形式是对一个数组的所有元素进行排序&#xff0c;并且是按照从小到大的排序。 public static void main(String[] args) {Integer []arr {1,2,3,4,5,6};//升序Arrays.sort(arr);for (int x:arr){System.out.print(x " ");}Sys…