牛客小白月赛100(下)

news2024/9/23 19:18:57

ACM中的C题

题目描述

登录—专业IT笔试面试备考平台_牛客网

运行代码

#include<iostream>
using namespace std;
int main()
{
    int n;
    cin>>n;
    if(n==1)
        cout<<-1;
    else if(n%2==0)
        cout<<n/2;
    else
        cout<<n/2+1;
}

代码思路 

一、总体思路

这段代码的目的是解决一个数组元素的交换问题,使得每个位置的元素与初始状态不同,同时要求输出最小交换次数。如果无法满足条件则输出 -1。

二、具体步骤原理

  1. 输入整数 n:通过 cin 从标准输入读取一个正整数 n,表示数组的长度。

  2. 判断特殊情况:如果 n 等于 1:当数组长度为 1 时,由于只有一个元素,无法进行交换使得元素与原来不同,所以输出 -1。

  3. 处理偶数长度数组:如果 n 是偶数:对于偶数长度的数组,可以通过两两交换相邻元素来满足每个位置的元素和原来都不相同的条件。例如,对于长度为 4 的数组 [a, b, c, d],可以交换为 [b, a, d, c]。此时最小交换次数为 n/2,因为每两对相邻元素进行一次交换即可。

  4. 处理奇数长度数组:如果 n 是奇数:类似地,对于奇数长度的数组,可以先将前 n - 1 个元素按照偶数长度数组的方法进行交换,然后最后一个元素与前面的某个元素交换位置。例如,对于长度为 5 的数组 [a, b, c, d, e],先将前四个元素交换为 [b, a, d, c],然后再将 e 与 a(或 bcd 中的任意一个)交换位置。所以最小交换次数为 n/2 + 1,其中 n/2 是前 n - 1 个元素的交换次数,再加上最后一个元素的一次交换。

ACM中的M题

题目描述

登录—专业IT笔试面试备考平台_牛客网

运行代码

#include <iostream>
#include <unordered_map>

using namespace std;

int main() {
    int n;
    cin >> n;
    unordered_map<int, int> a;
    for (int i = 0; i < n; ++i) {
        int x;
        cin >> x;
    }
    for (int i = 0; i < n; ++i) {
        int y;
        cin >> y;
        a[y]++;
    }
    bool flag = false;
    int ans = 0;
    for (const auto& pair : a) {
        if (pair.second == 1) {
            flag = true;
            break;
        } else {
            ans += (pair.second + 1) / 2;
        }
    }
    if (flag) {
        cout << -1 << endl;
    } else {
        cout << ans << endl;
    }
    return 0;
}

代码思路

一、总体思路

这段代码主要用于处理输入的一系列整数,统计每个整数的出现次数,然后根据统计结果进行特定的计算和输出。

二、具体步骤原理

  1. 读取整数 n:从标准输入读取一个整数 n,代表后续输入的整数个数。

  2. 忽略第一轮输入:通过一个循环读取 n 个整数 x,但不对这些输入做任何处理。

  3. 统计第二轮输入的整数出现次数:再次通过一个循环读取 n 个整数 y。对于每个读取到的整数 y,将其作为键,在 unordered_map a 中对应的值进行累加。这样就统计了每个整数在第二轮输入中出现的次数。

  4. 检查是否有整数只出现一次并计算结果

    • 遍历 unordered_map a
    • 对于每个键值对 pair,检查其值 pair.second(即对应整数的出现次数)。
    • 如果出现次数为 1,则设置标志 flag为 true,表示存在只出现一次的整数,跳出遍历。
    • 如果出现次数不为 1,则计算 (pair.second + 1) / 2并累加到 ans中。这里的计算可能是基于特定的问题需求,例如对于某个整数出现 k 次,可能需要进行某种操作,而这个操作的代价可以通过 (k + 1) / 2来计算。
  5. 输出结果

    • 根据标志 flag的值进行输出。
    • 如果 flag为 true,说明存在只出现一次的整数,按照要求输出 -1,表示无法满足特定条件。
    • 如果 flag为 false,则输出 ans,这个值是经过前面的计算得到的满足特定条件的结果。

ACM中的AC题

题目描述

登录—专业IT笔试面试备考平台_牛客网

运行代码

#include <iostream>
#include <queue>
#include <vector>
#include <array>
#include <climits>

using namespace std;

typedef pair<int, int> PII;
const int N = 2010;
int n, m, sx, sy;
char g[N][N];
int dist[N][N];
int dist1[N][N];
const int dir1[][2] = {{-1, 0}, {1, 0}, {0, 1}, {0, -1}};
const int dir2[][2] = {{1, 0}, {-1, 0}, {0, -1}, {0, 1}};

void init() {
    queue<PII> q;
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= m; j++) {
            if (g[i][j] == '@') {
                dist[i][j] = 0;
                q.push({i, j});
            }
        }
    }
    while (!q.empty()) {
        auto [x, y] = q.front();
        q.pop();
        for (int k = 0; k < 4; k++) {
            int xx = x + dir1[k][0];
            int yy = y + dir1[k][1];
            if (xx >= 1 && xx <= n && yy >= 1 && yy <= m && g[xx][yy]!= '#' && dist[xx][yy] == -1) {
                dist[xx][yy] = dist[x][y] + 1;
                q.push({xx, yy});
            }
        }
    }
}

void solve() {
    cin >> n >> m >> sx >> sy;
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= m; j++) {
            cin >> g[i][j];
            dist[i][j] = dist1[i][j] = -1;
        }
    }
    init();
    queue<array<int, 4>> q;
    q.push({sx, sy, sx, sy});
    dist1[sx][sy] = 0;
    int ans = INT_MAX;
    while (!q.empty()) {
        auto [x, y, a, b] = q.front();
        q.pop();
        if (g[x][y] == '@' && dist[a][b] >= 0) {
            ans = min(ans, dist1[x][y] + dist[a][b]);
        }
        if (g[a][b] == '@' && dist[x][y] >= 0) {
            ans = min(ans, dist1[a][b] + dist[x][y]);
        }
        for (int k = 0; k < 4; k++) {
            int xx = x + dir1[k][0];
            int yy = y + dir1[k][1];
            int aa = a + dir2[k][0];
            int bb = b + dir2[k][1];
            if (xx >= 1 && xx <= n && yy >= 1 && yy <= m && g[xx][yy]!= '#' && dist1[xx][yy] == -1 && aa >= 1 && aa <= n && bb >= 1 && bb <= m && g[aa][bb]!= '#' && dist1[aa][bb] == -1) {
                dist1[xx][yy] = dist1[x][y] + 1;
                dist1[aa][bb] = dist1[a][b] + 1;
                q.push({xx, yy, aa, bb});
            }
        }
    }
    if (ans == INT_MAX) {
        ans = -1;
    }
    cout << ans << '\n';
}

int main() {
    ios_base::sync_with_stdio(false);
    cin.tie(nullptr);
    cout.tie(nullptr);
    solve();
    return 0;
}

代码思路

一、总体思路

这段代码的目的是在一个给定的二维地图中,确定两个位于同一位置但只能反向移动的个体是否能够同时到达传送门,并计算出最短的移动序列长度,如果无法到达则输出 -1。

二、具体步骤原理

  1. 定义变量和常量

    • N:用于限定地图的最大尺寸。
    • nm:分别表示地图的行数和列数。
    • sxsy:起始位置的坐标。
    • g[N][N]:存储地图信息,字符代表不同的地块类型(平地、陷阱、传送门)。
    • dist[N][N]:用于存储从传送门到各个位置的最短距离。
    • dist1[N][N]:用于存储从起始位置出发,两个个体移动过程中的累积距离。
    • dir1dir2:分别表示两个个体移动的四个方向。
  2. 函数 init

    • 目的是初始化从传送门到各个位置的最短距离。
    • 使用广度优先搜索(BFS)的方法,从地图中的传送门位置开始,向四个方向扩展,逐步计算到各个位置的最短距离,并将这些距离存储在 dist 数组中。如果某个位置是陷阱或者已经访问过,则不进行扩展。
  3. 函数 solve

    • 主处理函数。
    • 首先读取地图的行数、列数和起始位置坐标,然后读取地图信息,并初始化 dist 和 dist1 数组为 -1,表示未访问。
    • 调用 init 函数初始化传送门到各个位置的最短距离。
    • 使用一个队列存储两个个体的位置状态,队列中的元素是一个包含四个整数的数组,表示两个个体的坐标 {x,y,a,b}。初始时将起始位置压入队列,并将 dist1[sx][sy] 设为 0。
    • 在循环中,每次从队列中取出一个状态,检查当前状态下两个个体的位置是否有一个到达传送门,并且另一个个体对应的传送门最短距离已知(非 -1)。如果满足条件,则计算当前状态下的总距离,并与已有的最小距离 ans 比较更新。
    • 然后尝试四个方向的移动,检查新的位置是否合法(在地图内且不是陷阱且未访问过),如果合法则更新新位置的距离,并将新状态压入队列。
    • 循环结束后,如果最小距离 ans 仍然是初始的极大值,则表示无法到达传送门,将其设为 -1 并输出;否则输出最小距离。

总之,这段代码通过 BFS 和状态扩展的方法,在二维地图中寻找两个只能反向移动的个体到达传送门的最短路径长度。其原理是利用了 BFS 能够找到最短路径的特性,以及对两个个体状态的同时处理来实现问题的求解。

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

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

相关文章

第二百二十一节 JPA教程 - JPA按ID查找示例

JPA教程 - JPA按ID查找示例 一旦我们将实体保存到数据库中&#xff0c;我们可以通过使用EntityManager中的find方法来检索它们。 以下代码显示如何使用find方法与实体id。 Person emp em.find(Person.class, 1L);例子 下面的代码来自Person.java。 package cn.w3cschool.…

Spring Boot 部署方案!打包 + Shell 脚本详解

本篇和大家分享的是springboot打包并结合shell脚本命令部署&#xff0c;重点在分享一个shell程序启动工具&#xff0c;希望能便利工作&#xff1b; profiles指定不同环境的配置 maven-assembly-plugin打发布压缩包 分享shenniu_publish.sh程序启动工具 linux上使用shenniu_p…

Telephony VOLTE配置

1、展锐 VOLTE配置 在配置运营商VOLTE业务时&#xff0c;虽然上层Carrierconfig默认配置VOLTE为关闭状态&#xff0c;但是发现只需要Modem侧配置为支持&#xff0c;上层就能够正常显示VOLTE开关。因此调查了一下相关逻辑 相关代码中可以看到只要"gsm.sys.sim.volte.allowe…

Enscape 4.1.0.2321 安装教程

软件介绍 Enscape 是专门为建筑、规划、景观及室内设计师打造的渲染产品&#xff0c;无需导入导出文件&#xff0c;在常用的软件内部即可看到逼真的渲染效果。 你无需了解记忆各种参数的用法&#xff0c;一切都是傻瓜式的一键渲染&#xff0c;你可以把精力更多地投入到设计中…

极限编程XP例题

答案&#xff1a;D 解析&#xff1a; 结对编程&#xff0c;一个人写代码&#xff0c;一个人看&#xff0c;由于是两个或两个以上的人负责&#xff0c;因此选项A 支持共同代码拥有和共同对系统负责是正确的 选项B 由于是一个人写一个人看&#xff0c;变相实现了代码审查 选项…

AI基础 L16 Logic Agents I

What is an Agent? • The main point about agents is they are autonomous: capable of acting independently, exhibiting control over their internal state • Thus: an agent is a computer system capable of autonomous action in some environment in order to mee…

网络编程(TCP通信)

【1】认识网络 网络&#xff1a;多设备通信 【2】IP地址 1.基本概念 IP地址是Internet中主机的标识Internet中的主机要与别的机器通信必须具有一个IP地址IP地址为32位&#xff08;IPv4&#xff09;或者128位&#xff08;IPv6&#xff09; NAT&#xff1a;公网转私网、私网转公网…

小样本目标定位:Few-shot Object Localization

论文&#xff1a;Few-shot Object Localization 代码&#xff1a;https://github.com/Ryh1218/FSOL 核心贡献&#xff1a; 1. 本文首次定义了小样本目标定位任务&#xff0c;为在标注数据有限的场景下进行目标定位提出了新的研究方向&#xff0c;并建立了高性能的基准。2. 提…

【详解!】什么是端点安全,端点安全策略如何设置?30秒带你了解端点安全!

端点&#xff0c;即接入网络的任何设备&#xff0c;如个人电脑、笔记本电脑、智能手机、平板电脑、服务器以及物联网(IoT)设备等&#xff0c;都是网络安全的潜在风险点。 端点安全&#xff0c;正是针对这些设备所采取的一系列安全措施&#xff0c;旨在保护它们免受恶意软件、未…

CSS【详解】图片相关样式(含object-fit ,object-position,lip-path,filter)

img 渲染图片&#xff0c;可以理解为一张镂空的白纸&#xff0c;通过镂空区域看到白纸下的图片。 图片尺寸 即镂空区域的大小 若未指定&#xff0c;则按图片原始尺寸显示&#xff1b;若指定&#xff0c;则默认按指定尺寸显示&#xff08;若指定尺寸的宽高比与原始的宽高比不同…

【虚拟化】KVM-virsh离线工具进行客户机虚拟机磁盘访问

目录 一、简介 二、常用离线命令 三、具体使用实例 1.virt-inspector 2.virt-cat 3.virt-edit 4.virt-df 5.virt-copy-out/virt-copy-in 6.guestmount 7.virt-diff 8.virt-customize 9.virt-sparsify 一、简介 Red Hat Enterprise Linux 7 提供多个 libguestfs 工具…

Leetcode 最长连续序列

算法流程&#xff1a; 哈希集合去重&#xff1a; 通过将数组中的所有元素放入 unordered_set&#xff0c;自动去除重复元素。集合的查找操作是 O(1)&#xff0c;这为后续的快速查找提供了保证。 遍历数组&#xff1a; 遍历数组中的每一个元素。对于每个元素&#xff0c;首先检…

OpenCV 与 YoloV3的结合使用:目标实时跟踪

目录 代码分析 1. YOLO 模型加载 2. 视频加载与初始化 3. 视频帧处理 4. 物体检测 5. 处理检测结果 6. 边界框和类别显示 7. 帧率&#xff08;FPS&#xff09;计算 8. 结果显示与退出 9. 资源释放 整体代码 效果展示 总结 代码分析 这段代码使用 YOLO&#xff08…

C++之函数的分文件编写

1.创建test.h的头文件 2.创建test.cpp的源文件 3.在头文件中写函数的声明 4.在源文件中写函数的定义 调用测试&#xff1a;

优雅的实现SSL证书的免费申请和续期【FreeSSL】

在今年上半年&#xff0c;各大厂商纷纷调整了免费SSL证书的有效期&#xff0c;将其从12个月缩短至3个月。这一变动给那些管理大量免费证书的人带来了很多麻烦&#xff0c;因为需要频繁地进行申请和部署。 今天我要介绍的是一种自动化申请证书的流程&#xff0c;可以实现多域名…

Python进阶——使用python操作数据库!

Python进阶——使用python操作数据库 一、数据库编程接口 为了对数据库进行统一操作&#xff0c;大多数语言都提供了简单的、标准的数据库接口python database api 2.0中&#xff0c;定义了python数据库api接口的各个部分&#xff0c;如模块接口、连接对象、游标对象、类型对…

物联网——DMA+AD多通道

DMA简介 存储器映像 某些数据在运行时不会发生变化&#xff0c;则设置为常量&#xff0c;存在Flash存储器中&#xff0c;节省运行内存的空间 DMA结构图 DMA访问权限高于cpu 结构要素 软件触发源&#xff1a;存储器到存储器传输完成后&#xff0c;计数器清零 硬件触发源&…

人员随机分组

如何实现男女比例平均分组&#xff1f; 在团队活动中&#xff0c;合理地将人员分组是一项重要的组织工作&#xff0c;它有助于提高团队合作的效率和质量。云分组小程序提供了一个便捷的解决方案&#xff0c;通过智能算法帮助用户快速实现人员分组。本文将详细介绍如何使用云分组…

网络通信安全:全面探索与深入分析

摘要&#xff1a;本文全面探索网络通信安全相关内容。首先阐述网络通信安全的基本概念与原理&#xff0c;包括网络通信模型、安全目标以及加密技术基础。接着详细分析其面临的威胁&#xff0c;涵盖恶意软件&#xff08;病毒、蠕虫、特洛伊木马&#xff09;、网络攻击&#xff0…

GAMES103——作业1 刚体碰撞

任务 1.更新位置、姿态与速度 2.碰撞检测 3.碰撞反馈 实现 更新位置、姿态与速度 对于速度的更新&#xff0c;采用显式的方法&#xff0c;对于位置的更新&#xff0c;采用隐式的方法。就是103中讲的两只青蛙的例子。 需要同时更新线速度和角速度。线速度受到重力的影响&#xf…