马蹄集oj赛(双周赛第二十三次)

news2025/1/12 8:53:08

目录

数列分割

小码哥的地毯

小码哥的三色墙

palace

高数考试

新全排列

黑白双煞

等差

数三角形

区间修改

相对马高

小码哥剪绳子


数列分割


难度:黄金 时间限制:1秒巴 占用内存:64 M
小码哥给你一个长度为n的数列,求将该数列分割成两个左右两个部分且两个部分内数字的和相等的方案数。
格式
输入格式:给定一整数n;
接下来有 n 个数 a[i]。
其中:1≤n≤ 105,ai]的绝对值不大于 10000。
输出格式:输出一行表示答案。

//
// Created by abner on 2024/3/22.
//
#include <bits/stdc++.h>
using namespace std;
const int N = 1e5 + 10;
long long n,a[N],sum [N],ans;

int main() {
    cin >> n;
    for (int i = 1; i <= n; i++) {
        cin >> a[i];
        sum[i] = sum[i - 1] + a[i];
    }
    for (int i = 2; i <= n; i++) {
        if (sum[n] - sum[i - 1] == sum[i - 1])
            ans++;
    }
    cout << ans;
    return 0;
}

小码哥的地毯


少 难度:黄金·时间限制:1秒四占用内存:128M
小码哥的房间要铺上地毯。房间大小为几*几,小码哥有m 块矩形地毯,给出每块地毯放置的两个对角的坐标。问每个点被多少个地毯覆盖
格式
输入格式:今第一行,两个整数n,m;接下来 m 行,每行两个坐标(1,y)和(2,y) 代表一块地毯,左上角是(1,y),右下角是(2,y2)。
输出格式:输出n行,每行几个整数;

//
// Created by abner on 2024/3/22.
//
#include <bits/stdc++.h>
using namespace std;
#define N 1005
int n,m;
int a[N][N],sub[N][N];
int main(){
    cin >>n >>m;
    for(int i=1;i<=m;++i){
            int x1,y1,x2,y2;
    cin >>x1 >>y1 >>x2 >>y2;
    sub[x1][y1] += 1;
    sub[x1][y2+1] -= 1;
    sub[x2+1][y1] -= 1;
    sub[x2+1][y2+1] += 1;
}
for (int i=1;i<=n;++i){
for (int j=1;j <= n;++j){
a[i][j]=sub[i][j]+a[i-1][j]+a[i][j-1]-a[i-1][j-1];
        cout <<a[i][j]<<" ";
}
puts("");
}
return 0;
}

小码哥的三色墙


难度:黄金时间限制:1秒巴 占用内存:128 M
小码哥的房间墙要重新刷漆。墙面大小可以看成几*m个小方块,每个方块初始颜色为W,B或R,小码哥对于刷漆的要求是:
1.从最上方若干行(至少一行)的格子全部是W色的;
2.接下来若干行(至少一行)的格子全部是B色的;
3.剩下的行(至少一行)全部是 色的。
小码哥想要更改最少的格子数来满足要求。请你帮他算算最少的更改数。

//
// Created by abner on 2024/3/22.
//
#include <bits/stdc++.h>
using namespace std;
#define N 1005
int n,m,w[N],b[N],r[N];
int ans = 0x3f3f3f3f;
string s;
int cal(char c) {
//某一行全部刷成某种颜色的代价
    int t = 0;
    for (int i = 0; i < m; ++i)
        if (s[i] != c)
            t++;
    return t;
}
int main() {
    cin >> n >> m;
    for (int i = 1; i <= n; ++i) {
        cin >> s;
        w[i] = w[i - 1] + cal('W');
        b[i] = b[i - 1] + cal('B');
        r[i] = r[i - 1] + cal('R');
    }
    for (int i = 1; i < n - 1; ++i)
        for (int j = i + 1; j < n; ++j)
            ans = min(ans, w[i] + b[j] - b[i] + r[n] - r[j]);
    cout << ans;
    return 0;
}

palace


难度:钻石时间限制:1秒巴 占用内存:128 M。
小码哥准备给自己盖一座很华丽的宫殿。于是,他看中了一块NxM 的矩形空地。
空地中每个格子都有自己的海拔高度。小码哥想让他的宫殿的平均海拔在海平面之上(假设海平面的高度是0,平均数都会算吧?)。而且,小码哥希望他的宫殿尽量大,能够容纳更多的人来膜拜他。请问小码哥的宫殿最后会有多大?
格式
输入格式:第一行两个整数 n,m;
之后 n 行,每行 m 个数,描述的空地的海拔。

//
// Created by abner on 2024/3/22.
//
#include <bits/stdc++.h>
using namespace std;
const int N = 210;
int n,m,a[N][N],sum [N][N],ans;

int main(){
    cin >>n >>m;
    for (int i=1;i <=n;i++)
        for (int j =1;j <=m;j++) {
            cin >> a[i][j];
            sum[i][j] =
                    sum[i - 1][j] + sum[i][j - 1] + a[i][j] - sum[i - 1][j - 1];
        }
    for (int i=1;i<=n;i++)
        for (int j =1;j <= m;j++)
            for (int k=i;k <= n;k++)
                for (int l=j;l <= m;l++) {
                    int tmp = (k - i + 1) * (l - j + 1);
                    int tmp2 = sum[k][l] - sum[i - 1][l] - sum[k][j - 1] +
                               sum[i - 1][j - 1];
                    if (tmp > ans && tmp2 > 0)
                        ans = tmp;
                }
    cout << ans;
    return 0;
}

高数考试


黄金!巴 占用内存:128 M子难度:时间限制:1秒
高数考完了,又到了数学老师难办的时候。数学老师想捞同学一把,她总是要一遍遍地给某些同学增加分数(均为正整数),又要注意最低分是多少。由于工作量很大,你能帮帮她吗?
格式
输入格式:第一行有两个整数n,p,代表学生数与增加分数的次数第二行有 n 个数,a1~ an ,代表各个学生的初始成绩;接下来p行,每行有三个数 ,y,z,代表给第  个到第y个学生每人增加z分。

/*
    MT2068 高数考试 
*/

#include<bits/stdc++.h> 
using namespace std;

const int MAX = 5e6+5;
int ary[MAX], sub[MAX];

int main( )
{
    // 录入数据 
    int n,p,x,y,z,minScore=MAX; 
	cin>>n>>p; 

    // 录入分数时同时记录差分数组 
    for(int i=1;i<=n;i++){
        cin>>ary[i];
        sub[i] = ary[i] - ary[i-1];
	}

	// 录入操作时只需要对差分数组进行修改 
    while(p--){
        cin>>x>>y>>z;
        sub[x] += z;
        sub[y+1] -=z;
	}

    // 还原数组并找出最小值 
    for(int i=1;i<=n;i++){
        ary[i] = ary[i-1] + sub[i];
        minScore = min(minScore, ary[i]);
	}

    // 输出最低分数 
	cout<<minScore<<endl;

    return 0;
}

新全排列


 时间限制:2秒难度:钻石四:占用内存:256 M
列数组 P1,P2,?3,..,?n 被称作一个全排列当且仅当1到n所有数都出现一次。现有一个n的全排列 p1,p2,p3,·..,pn ,仅知道 q1,q2,3,·..,qn-1的序列,其中 qi=pi+1-Pi。
要求求出原序列。
格式
输入格式:第一行输入 n(2 <n<2*105)原序列长度;第二行输入 q1, 92, q3,·..,qn-1(-n < qi< n)。

//
// Created by abner on 2024/3/22.
//
#include <bits/stdc++.h>
using namespace std;
const int N =2e5+ 7;

int n,p[N],q[N],tmp[N];
bool flag;
int main() {
    cin >> n;
    for (int i = 1; i <= n - 1; i++)
        cin >>q[i];//差分数组前缀和就是原数组
    int minn = 0;

    for (int i=2;i<=n;i++){
        p[i]=p[i-1]+q[i-1];
    if (p[i] < minn)
    minn = p[i];
}
for (int i=1;i<=n;i++) {
    p[i] = p[i] - minn + 1;
    tmp[i] = p[i];
    if (tmp[i] > n || tmp[i] < 1) {
        cout << -1;
        return 0;
    }
}
sort(tmp + 1,tmp +n + 1);
for (int i=1;i<=n-1;i++)
if (tmp[i]==tmp[i + 1]){
    cout<<-1;
    return 0;
}
    for (int i=1;i<=n;i++)
        cout << p[i] <<" ";
    return 0;
}

黑白双煞


难度:钻石时间限制:1秒巴:占用内存:128 M
小码哥现在手里一个环(首尾相连),环上有(2<n<100000)个点,每个点必定是两种颜色之一(黑色或白色)。
现在他想请你进行一些操作,每次交换两个点的位置,求最少操作次数使得黑白色的几个点分离成两个部分,每个部分只含一种颜色。
格式
输入格式:第-行-个正整数n(2≤n≤ 100000);
接下来一行一个字符串 S ,长度为 n ,第讠位为 H 则表示黑点,T 则表示白点。

//
// Created by abner on 2024/3/22.
//
#include <bits/stdc++.h>
using namespace std;
const int N=1e5 + 10;
int a[N << 1],sum[N << 1];
int n,cnt,ans;//cnt表示黑色的个数,ans表示cnt长的区间内,最多多少个黑色
char ch;
int main(){
    cin >> n;
    for (int i=1;i<=n;i++) {
        cin >> ch;
        if (ch == 'H')//黑色为1
            a[i + n] = a[i] = 1, cnt++;
    }
        for (int i=1;i<=n * 2;i++)
        sum[i]=sum[i-1]+a[i];//前缀和,前面有多少个黑色
        
        for (int i=1;i <=n;i++)
            ans = max(ans,sum[i+cnt - 1] - sum[i-1]);
        
        cout <<cnt - ans;
        return 0;
    }

等差


难度:钻石时间限制:1秒四: 占用内存:256 M
学完等差数列的小码哥神清气爽,他想在一长串数中找到等差的部分。
他给你一个整数数组nums,要求该数组中所有为等差数组的子数组个数(等差数组子数组,指的是至少3个数的连续数组成等差数列)。
格式
输入格式:一个整数数组。
输出格式:返回一个非负整数。

//
// Created by abner on 2024/3/22.
//
#include <bits/stdc++.h>
using namespace std;
const int N = 5010;
int nums [N],sub[N],n,ans;

int main(){
    int x;
    while (cin >>x){
        n++;
        nums[n] = x;
        sub[n] = nums[n] - nums[n - 1];
    }
    for (int i=2;i<n;i++){
        int tmp = sub[i],index = i+1,t=0;
        while (sub [index]==tmp) {
            t++;
            index++;
        }
            ans +=t;
        }
        cout <<ans;
        return 0;
    }

数三角形


时间限制:1秒难度:钻石巴: 占用内存:128 M
给出四个整数 A, B,C,D ,其中 1< A≤B<C<D<5.105
求三边长分别为 æ, y,z(㎡,y,z为整数)并且満足 A≤æ≤B≤y≤C≤z≤D 的非退化三角形(三顶点不共线)的个数。
格式
输入格式:第一行为 A,B,C,D
输出格式:输出一个整数为答案。

//
// Created by abner on 2024/3/22.
//
#include <bits/stdc++.h>
using namespace std;
const int N=5e5 +5;
long long a[N],sum[N],A,B,C,D,ans;
int main(){
    cin >>A >>B>>C>>D;
    for (int i=A;i<=B;i++)
        for (int j=B;j<=C;j++)
            a[i+j]++;
    for (int i=A+B;i <= B+C;i++)
        sum[i] = sum[i -1] + a[i];
    for(int i=C;i <= min(D,B+C);i++)
        ans += sum[B + C] - sum[i];
    cout <<ans;
    return 0;
}

区间修改


难度:黄金
时间限制:1秒巴:占用内存:128 M
小码哥有几个手下,他们的编号为1,n。小码哥想要给他们发放工资,用一个长度为n的数列ai,表示编号为i的手下初始收到的工资,但发工资时没有计算好,导致每个人到手的工资不-样,为了使他们的工资相同,现在小码哥可以使得编号在区间,中的手下,收到1或上交1的工资。即工资+1或工资-1;
求至少需要多少次操作才能使所有人的工资相同都一样?
工资可以暂时为负数,小码哥可以压榨他的手下,让手下暂时垫付部分钱,之后再还;小码哥也可以多付一些钱给手下,也可以少给一些(自己贪污一点),即工资总数不要求一定是初始手下的工资之和。只要他们每个人的工资一样就可以。

//
// Created by abner on 2024/3/22.
//
#include <bits/stdc++.h>
using namespace std;
const int N = 1e5 + 10;
int n,a[N],sub[N],num1,num2;
int main(){
    int ans =0,buf =0;
    cin >>n;
    for (int i=1;i<=n;i++)
        cin >>a[i];
    for (int i=2;i<=n;i++){
        sub[i] = a[i]-a[i-1];
        if (sub[i] > 0)
        num1 += sub[i];
        else 
        num2 += sub[i];
    }
    cout <<max(num1,-num2);
    return 0;
}

相对马高


少难度:黄金时间限制:1秒四: 占用内存:128 M
小码哥有几头马,他们站作一排,由于马的身高不同,如果马A和B能够相互看见,那么,在(a,b)区间的马的身高都小于 a,b马。
现在给出最高的马的身高h。之后小码哥将给出f组数据,表示马A,B可以相互看见,请你推出小码哥的马们的最大的可能的身高,由于小码哥工作向来随性,马的区间顺序关系可能写错(数据不确保 a<b)。
格式
输入格式:第 1 行输入 n,h,f;
第 2 行到第 f+1 行 输入两个数据 a,b,以空格分隔

//
// Created by abner on 2024/3/22.
//
#include <bits/stdc++.h>
using namespace std;
const int N = 1e4 + 10;
int n,h,f,g[N],sub[N],a,b;
int main() {
    cin >> n >> h >> f;
    sub[1] = h;
    while (f--) {
        cin >> a >> b;
        if (a == b)
            continue;
        if (a > b)
            swap(a, b);
        sub[a + 1] -= 1;
        sub[b] += 1;
    }
    for (int i = 1; i <= n; i++) {
        g[i] = g[i - 1] + sub[i];
        cout << g[i] << endl;
    }
    return 0;
}

小码哥剪绳子


时间限制:1秒巴 占用内存:128 M了 难度:黄金
马上就要到文化节了,小码哥身为学生会的一员需要参与到道具制作。
由于被分配到趣味拔河,小码哥需要切绳子,有N 条绳子,它们的长度分别为,n。
如果从它们中切割出 K 条长度相同的绳子,这条绳子每条最长能有多长?
格式
输入格式:第一行两个整数 N 和K;
接下来 N 行,每行一个整数代表每条绳子的长度 工。

//
// Created by abner on 2024/3/22.
//
#include <bits/stdc++.h>
using namespace std;
const int M = 1e5 + 10;
int L[M],N,K,l,r,mid,ans;

bool check(int num){
    int tmp =0;
    for (int i =1;i<=N;i++) {
        tmp += L[i] / num;
    }
        if (tmp >=K)
            return true;
        else
            return false;
    }
    int main(){
        cin >>N>>K;
        for (int i=1;i<=N;i++) {
            cin >> L[i];
            r = max(r, L[i]);
        }
            while (l <=r){
                mid = l+(r-l)/2;
                if (check(mid))
                    l=mid + 1,ans = mid;
                else
                r = mid - 1;
            }
        cout <<ans;
        return 0;
    }

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

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

相关文章

【CVTE 一面凉经Ⅰ】循环依赖如何解决

目录 一.&#x1f981; 开始前的废话二. &#x1f981; 什么是循环依赖&#xff1f;三. &#x1f981;Spring 容器解决循环依赖的原理是什么?五. &#x1f981; 三级缓存解决循环依赖的原理六. &#x1f981; 由有参构造方法注入属性的循环依赖如何解决&#xff1f;七.&#x…

【算法分析与设计】相同的树

题目 给你两棵二叉树的根节点 p 和 q &#xff0c;编写一个函数来检验这两棵树是否相同。 如果两个树在结构上相同&#xff0c;并且节点具有相同的值&#xff0c;则认为它们是相同的。 示例 示例 1&#xff1a; 输入&#xff1a;p [1,2,3], q [1,2,3] 输出&#xff1a;true示…

IDEA创建Maven项目实现数据库表查询

在此之前&#xff0c;务必确保你本地环境已经正确配置了 JDK 和 Maven&#xff0c;并且相关的环境变量已经设置。这是你踏上编程之旅的第一步&#xff0c;也是你与代码交互的基础。可通过命令提示符中输入 java -version 和 mvn -v 命令&#xff0c;以验证你的 JDK 和 Maven 是…

多ip多进程代理的实现方法

目录 写在前面 一、背景 二、实现方法 1. 使用多线程处理代理请求 2. 使用多进程处理代理请求 3. 实现多IP代理 三、总结 写在前面 实现多IP多进程代理需要使用Python的多线程和多进程模块。本文将介绍如何使用这些模块来实现多IP多进程代理&#xff0c;并提供相关的代…

蓝桥杯练习——神秘咒语——axios

目标 完善 index.js 中的 TODO 部分&#xff0c;通过新增或者修改代码&#xff0c;完成以下目标&#xff1a; 点击钥匙 1 和钥匙 2 按钮时会通过 axios 发送请求&#xff0c;在发送请求时需要在请求头中添加 Authorization 字段携带 token&#xff0c;token 的值为 2b58f9a8-…

五.java数组

1.int [] arr{1,2,3} 2.lenarr.length; 3.数组内存执行原理 java程序编译后产生一个class文件然后提交到内存中的虚拟机JVM中去运行&#xff0c;java为了便于虚拟机运行程序就将虚拟机的这块内存划分为5个区域&#xff1a;方法区&#xff0c;栈&#xff0c;堆。。。 经典函数…

Matlab快捷键与函数

注释&#xff1a;注释对于代码的重要性我们就不做过多的解释了。不做注释的代码不是好代码。选中要注释的语句&#xff0c;按快捷键CtrlR,或者在命令行窗口上面的注释地方可以进行注释。当然也可以直接在语句前面“%”就可以&#xff08;注意&#xff1a;一定要用英文符号&…

BigDecimal类的使用,用于精确计算任意精度的数字

BigDecimal类 BigDecimal 是 Java 中用于精确表示任意精度的十进制数的类。在很多情况下,使用基本数据类型(如 double 或 float)进行浮点数计算可能会导致精度丢失或舍入错误。BigDecimal 提供了一种更精确的解决方案,可以处理需要高精度计算的场景,比如财务应用或科学计算…

29-3 哥斯拉安装使用

环境准备:构建完善的安全渗透测试环境:推荐工具、资源和下载链接_渗透测试靶机下载-CSDN博客 一、哥斯拉 (Godzilla) 介绍 哥斯拉是一个基于流量、HTTP全加密的webshell管理工具,具有以下特点: 内置了3种Payload以及6种加密器,6种支持脚本后缀,20个内置插件基于Java,可…

第十三届蓝桥杯省赛真题 Java B 组【原卷】

文章目录 发现宝藏【考生须知】试题 A: 星期计算试题 B: 山试题 C: 字符统计试题 D: 最少刷题数试题 E \mathrm{E} E : 求阶乘试题 F : \mathrm{F}: F: 最大子矩阵试题 G: 数组切分试题 H: 回忆迷宫试题 I: 红绿灯试题 J 拉箱子 发现宝藏 前些天发现了一个巨牛的人工智能学习…

仿muduo库实现one thread one loop式并发服务器

文章目录 一、项目简介 二、项目整体认识 2、1 HTTP服务器 2、2 Reactor模型 三、预备知识 3、1 C11 中的 bind 3、2 简单的秒级定时任务实现 3、3 正则库的简单使用 3、4 通用类型any类型的实现 四、服务器功能模块划分与实现 4、1 Buffer模块 4、2 Socket模块 4、3 Channel模…

【TD3思路及代码】【自用笔记】

1 组成&#xff08;Target Network Delayed Training&#xff09; Actor网络&#xff1a;这个网络负责根据当前的状态输出动作值。在训练过程中&#xff0c;Actor网络会不断地学习和优化&#xff0c;以输出更合适的动作。Critic网络&#xff1a;TD3中有两个Critic网络&#xff…

解决:springboot项目访问hdfs文件提示guava版本不兼容

1、问题描述 版本说明&#xff1a;我用的hadoop版本&#xff1a;3.1.3 项目可以正常启动&#xff0c;但是调用访问hdfs的服务时候报错,报错消息如下&#xff1a;com.google.common.base.preconditions.checkArgument(ZL java/lang/String;Ljava/lang/Object:)V 原因分析&#x…

力扣 字符串解码

维护一个放数字的栈&#xff0c;一个放字母的栈 遇到[把数字和字母入栈&#xff0c;遇到]把当前字母循环加上数字栈头遍的字母栈头 class Solution { public:string decodeString(string s) {string ans"";stack<int>sz;stack<string>zm;里面是string …

蓝桥杯(3.22 刷真题)

P8682 [蓝桥杯 2019 省 B] 等差数列 RE是因为除以0的情况 import java.util.Arrays; import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner sc new Scanner(System.in);int n sc.nextInt();int[] res new int[n1];for(int i1;i&l…

集合深入------理解底层。

集合的使用 前提&#xff1a;栈、堆、二叉树、hashcode、toString()、quesalus()的知识深入和底层理解。 1、什么是集合 集合就是咋们所说的容器 ​ 前面我们学习过数组 数组也是容器 ​ 容器&#xff1a;装东西的 生活中有多少的容器呀? 水杯 教室 酒瓶 水库 只要是…

【论文速读】| 视觉对抗样本:突破对齐的大语言模型

本次分享论文为&#xff1a;Visual Adversarial Examples: Jailbreak Aligned Large Language Models 基本信息 原文作者&#xff1a;Xiangyu Qi, Peter Henderson, Kaixuan Huang, Ashwinee Panda, Mengdi Wang, Prateek Mittal 作者单位&#xff1a;普林斯顿大学、斯坦福大…

算法打卡day20|二叉树篇09|Leetcode 669. 修剪二叉搜索树、108.将有序数组转换为二叉搜索树、538.把二叉搜索树转换为累加树

算法题 Leetcode 669. 修剪二叉搜索树 题目链接:669. 修剪二叉搜索树 大佬视频讲解&#xff1a;修剪二叉搜索树视频讲解 个人思路 把这道题想复杂了&#xff0c;还想着如何去重构树 解法 递归法 依旧递归三步走 1.确定递归函数的参数以及返回值 这题递归需要返回值&#…

NVMe开发——NAND Flash的基本原理

1. 存储单元 1.1. 半导体 半导体&#xff08;semiconductor&#xff09;指常温下导电性能介于导体与绝缘体之间的材料。纯净半导体一般是四价原子(如硅或锗)。 1.1.1. P型半导体 P型半导体是通过将一个纯净的半导体材料&#xff08;如硅或锗&#xff09;中掺杂少量的三价杂…

软件管理rpm与yum

源代码包下载 Compare, Download & Develop Open Source & Business Software - SourceForgehttps://sourceforge.net/ rpm包下载 Welcome to the RPM repository on fr2.rpmfind.nethttp://rpmfind.net/linux/RPM/ 软件包管理 1.rpm包管理: 1)查询: 安装…