阿里巴巴找黄金宝箱(I)【华为OD机试-JAVAPythonC++JS】

题目描述

一贫如洗的樵夫阿里巴巴在去砍柴的路上,无意中发现了强盗集团的藏宝地,藏宝地有编号从0~N的箱子,每个箱子上面贴有一个数字,箱子中可能有一个黄金宝箱。
黄金宝箱满足排在它之前的所有箱子数字和等于排在它之后的所有箱子数字和;第一个箱子左边部分的数字和定义为0;最后一个宝箱右边部分的数字和定义为0。
请帮阿里巴巴找到黄金宝箱,输出第一个满足条件的黄金宝箱编号,如果不存在黄金宝箱,请返回-1。
输入描述:
箱子上贴的数字列表,使用逗号分隔,例如1,-1,0。
宝箱的数量不小于1个,不超过10000
宝箱上贴的数值范围不低于-1000,不超过1000
输出描述:
第一个黄金宝箱的编号
用例1
输入
2,5,-1,8,6
1
输出
3
1
说明:
下标3之前的数字和为:2 + 5 + -1 = 6
下标3之后的数字和为:6 = 6
用例2
输入:
8,9
1
输出:
-1
1
说明:
不存在符合要求的位置
用例3
输入:
11
1
输出:
0
1
说明:
下标0之前的数字和为:0
下标0之后的数字和为:0

解题思路

这个问题的解题思路是通过遍历每个箱子,判断当前箱子是否为黄金宝箱。对于每个箱子,需要计算它之前和之后的数字和,然后比较两者是否相等。如果相等,那么当前箱子就是黄金宝箱。

具体步骤如下:

  1. 初始化左右两部分的和,分别为 left_sumright_sum
  2. 遍历每个箱子,对于第i个箱子,计算左部分的和(不包括第一个数字)和右部分的和(不包括当前数字)。
  3. 判断左部分的和是否等于右部分的和,如果相等,则当前箱子是黄金宝箱,输出它的编号,设置标志为 flag = true,并且退出循环。
  4. 如果遍历完所有箱子都没有找到黄金宝箱,输出-1。

这个思路通过遍历一次数组,进行一些累加和减操作,能够有效找到第一个满足条件的黄金宝箱。

题解代码

Python题解代码

import sys

# 输入
input = sys.stdin.readline().strip()
nums = list(map(int, input.split(',')))
n = len(nums)

# 初始化左右两部分的和
left_sum = 0
right_sum = sum(nums)

# 遍历每个箱子,判断是否为黄金宝箱
flag = False  # 是否找到黄金宝箱的标志
for i in range(n):
    if i != 0:  # 左部分的和不包括第一个数字
        left_sum += nums[i - 1]
    right_sum -= nums[i]  # 右部分的和不包括当前数字
    if left_sum == right_sum:  # 判断是否为黄金宝箱
        print(i)  # 输出黄金宝箱的编号
        flag = True  # 找到了黄金宝箱
        break  # 直接退出循环

# 输出结果
if not flag:  # 如果没有找到黄金宝箱
    print(-1)  # 输出-1


JAVA题解代码

import java.util.Scanner;
import java.util.ArrayList;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        // 输入
        String input = scanner.nextLine();
        String[] numsStr = input.split(",");  // 以逗号为分隔符,分割数字字符串
        ArrayList<Integer> nums = new ArrayList<>();  // 存储输入的数字
        for (String numStr : numsStr) {
            nums.add(Integer.parseInt(numStr));  // 将字符串转换成整数并存入nums中
        }
        int n = nums.size();  // 数字个数
        // 初始化左右两部分的和
        int left_sum = 0, right_sum = 0;
        for (int num : nums) {  // 计算所有数字的和,作为右部分的和
            right_sum += num;
        }
        // 遍历每个箱子,判断是否为黄金宝箱
        boolean flag = false;  // 是否找到黄金宝箱的标志
        for (int i = 0; i < n; i++) {
            if (i != 0) {  // 左部分的和不包括第一个数字
                left_sum += nums.get(i - 1);
            }
            right_sum -= nums.get(i);  // 右部分的和不包括当前数字
            if (left_sum == right_sum) {  // 判断是否为黄金宝箱
                System.out.println(i);  // 输出黄金宝箱的编号
                flag = true;  // 找到了黄金宝箱
                break;  // 直接退出循环
            }
        }
        // 输出结果
        if (!flag) {  // 如果没有找到黄金宝箱
            System.out.println(-1);  // 输出-1
        }
    }
}


C/C++题解代码

#include <iostream>
#include <string>
#include <sstream>
#include <vector>
using namespace std;

int main() {
    // 输入
    string input;
    getline(cin, input);  // 获取一行输入
    stringstream ss(input);  // 将输入转换成stringstream对象,便于逐个获取数字
    vector<int> nums;  // 存储输入的数字
    string temp;  // 用于逐个获取数字的临时变量
    while (getline(ss, temp, ',')) {  // 逐个获取数字,以逗号为分隔符
        nums.push_back(stoi(temp));  // 将字符串转换成整数并存入nums中
    }
    int n = nums.size();  // 数字个数
    // 初始化左右两部分的和
    int left_sum = 0, right_sum = 0;
    for (int num : nums) {  // 计算所有数字的和,作为右部分的和
        right_sum += num;
    }
    // 遍历每个箱子,判断是否为黄金宝箱
    bool flag = false;  // 是否找到黄金宝箱的标志
    for (int i = 0; i < n; i++) {
        if (i != 0) {  // 左部分的和不包括第一个数字
            left_sum += nums[i - 1];
        }
        right_sum -= nums[i];  // 右部分的和不包括当前数字
        if (left_sum == right_sum) {  // 判断是否为黄金宝箱
            cout << i;  // 输出黄金宝箱的编号
            flag = true;  // 找到了黄金宝箱
            break;  // 直接退出循环
        }
    }
    // 输出结果
    if (!flag) {  // 如果没有找到黄金宝箱
        cout << -1;  // 输出-1
    }
    return 0;
}


JS题解代码

const readline = require('readline');

const rl = readline.createInterface({
  input: process.stdin,
  output: process.stdout
});

rl.on('line', function (line) {
  // 输入
  const input = line.trim();
  const nums = input.split(',').map(Number);
  const n = nums.length;
  // 初始化左右两部分的和
  let left_sum = 0, right_sum = nums.reduce((sum, num) => sum + num, 0);
  // 遍历每个箱子,判断是否为黄金宝箱
  let flag = false;  // 是否找到黄金宝箱的标志
  for (let i = 0; i < n; i++) {
    if (i !== 0) {  // 左部分的和不包括第一个数字
      left_sum += nums[i - 1];
    }
    right_sum -= nums[i];  // 右部分的和不包括当前数字
    if (left_sum === right_sum) {  // 判断是否为黄金宝箱
      console.log(i);  // 输出黄金宝箱的编号
      flag = true;  // 找到了黄金宝箱
      break;  // 直接退出循环
    }
  }
  // 输出结果
  if (!flag) {  // 如果没有找到黄金宝箱
    console.log(-1);  // 输出-1
  }
});


代码OJ评判结果

通过测试点

代码讲解

Python题解代码讲解

  1. 导入模块: 首先导入了sys模块,用于标准输入。
  2. 输入: 通过sys.stdin.readline().strip()获取输入字符串,然后使用map函数和split方法将字符串转换为整数列表。
  3. 初始化左右两部分的和: 使用left_sumright_sum分别表示左右两部分的和,初始时右部分的和为整个数组的和。
  4. 遍历每个箱子: 通过循环遍历每个箱子,计算当前箱子左右两部分的和,然后判断是否为黄金宝箱。
  5. 输出结果: 如果找到黄金宝箱,则输出它的编号;否则,输出-1。

JAVA题解代码讲解

  1. 导入模块: 导入了java.util.Scannerjava.util.ArrayList两个模块。
  2. 输入: 使用Scanner类获取输入字符串,然后通过split方法将字符串分割成字符串数组,再将每个字符串转换为整数存入ArrayList
  3. 初始化左右两部分的和: 使用left_sumright_sum分别表示左右两部分的和,初始时右部分的和为整个数组的和。
  4. 遍历每个箱子: 通过循环遍历每个箱子,计算当前箱子左右两部分的和,然后判断是否为黄金宝箱。
  5. 输出结果: 如果找到黄金宝箱,则输出它的编号;否则,输出-1。

C/C++题解代码讲解

  1. 导入模块: 导入了iostreamstringsstreamvector四个标准库。
  2. 输入: 使用getline(cin, input)获取输入字符串,然后通过stringstream对象逐个获取数字并存入vector
  3. 初始化左右两部分的和: 使用left_sumright_sum分别表示左右两部分的和,初始时右部分的和为整个数组的和。
  4. 遍历每个箱子: 通过循环遍历每个箱子,计算当前箱子左右两部分的和,然后判断是否为黄金宝箱。
  5. 输出结果: 如果找到黄金宝箱,则输出它的编号;否则,输出-1。

JS题解代码讲解

  1. 导入模块: 使用Node.js的readline模块,创建一个readline接口。
  2. 输入: 通过rl.on('line', function (line)监听输入,获取输入字符串,然后通过split方法将字符串分割成数字数组。
  3. 初始化左右两部分的和: 使用left_sumright_sum分别表示左右两部分的和,初始时右部分的和为整个数组的和。
  4. 遍历每个箱子: 通过循环遍历每个箱子,计算当前箱子左右两部分的和,然后判断是否为黄金宝箱。
  5. 输出结果: 如果找到黄金宝箱,则输出它的编号;否则,输出-1。

寄语

🚀✨ 朋友,希望你的华为OD机试就像是一场轻松的技术party!愿你的代码如同畅快的音符,跳跃在键盘上,最后弹奏出一曲高分之歌。加油,你是技术舞台上的巨星!通过机试,就像是风轻云淡,轻轻松松就把高分收入囊中。祝愿你的编程之旅一路顺风,破风前行,每一行代码都是成功的注脚!🌈💻

在这里插入图片描述

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

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

相关文章

Android 性能优化--APK加固(1)混淆

文章目录 为什么要开启混淆如何开启代码混淆如何开启资源压缩代码混淆配置代码混淆后&#xff0c;Crash 问题定位结尾 本文首发地址&#xff1a;https://h89.cn/archives/211.html 最新更新地址&#xff1a;https://gitee.com/chenjim/chenjimblog 为什么要开启混淆 先上一个 …

“智农”-高标准农田

高标准农田是指通过土地整治、土壤改良、水利设施、农电配套、机械化作业等措施&#xff0c;提升农田质量和生产能力&#xff0c;达到田块平整、集中连片、设施完善、节水高效、宜机作业、土壤肥沃、生态友好、抗灾能力强、与现代农业生产和经营方式相适应的旱涝保收、稳产高产…

BUUCTF---wireshark1

1.题目描述 2.下载附件是一个.pcap的文件 3.需要用到wireshark工具&#xff0c;用该工具打开文件 4.用户在登录密码时一般不会用get方式提交&#xff0c;因为这样不安全&#xff0c;相比较而言post安全一点。 5.使用http.request.methodPOST命令进行过滤&#xff0c;得到一条流…

道路千万条,安全第一条,如何让机器人更安全?

停的住&#xff0c;停的稳&#xff0c;该避就避&#xff0c;该停就停。 商用机器人实现落地的前提有很多&#xff0c;但安全问题毫无疑问是重中之重。尤其随着机器人的应用场景开始向复杂化、小型化方向拓展&#xff0c;对机器人的安全能力要求更是与日俱增。如何保证机器人在…

供水管网水力模型的建立与应用

阐述管网水力模型构建流程,建立供水管网水力模型。通过数据录入生成管网基本拓扑结构及物理信息,在模型简化之后利用监测数据进行模型校核,保障管网模型满足精度要求。利用管网模型进行管网工况分析,掌握管网内压力分布与管道流速分布状态,提出管网运行薄弱环节。 给…

测试环境搭建整套大数据系统(七:集群搭建kafka(2.13)+flink(1.13.6)+dinky(0.6)+iceberg)

一&#xff1a;搭建kafka。 1. 三台机器执行以下命令。 cd /opt wget wget https://dlcdn.apache.org/kafka/3.6.1/kafka_2.13-3.6.1.tgz tar zxvf kafka_2.13-3.6.1.tgz cd kafka_2.13-3.6.1/config vim server.properties修改以下俩内容 1.三台机器分别给予各自的broker_id…

C++设计模式之——享元模式详解和代码案例

文章目录 C中实现享元模式通常涉及以下几个关键部分&#xff1a;一个简单的C代码片段示例享元模式的进一步说明C享元模式代码案例——咖啡店订单系统享元模式在现实世界的应用场景 C中实现享元模式通常涉及以下几个关键部分&#xff1a; 享元模式&#xff08;Flyweight Patter…

【Java设计模式】二、单例模式

文章目录 0、单例模式1、饿汉式2、懒汉式3、双重检查4、静态内部类5、枚举6、单例模式的破坏&#xff1a;序列化和反序列化7、单例模式的破坏&#xff1a;反射8、单例模式的实际应用 设计模式即总结出来的一些最佳实现。GoF(四人组) 书中提到23种设计模式&#xff0c;可分为三大…

linux c++ 开发 tensorrt 安装

tensorrt 官方下载地址&#xff08;需要注册账号登录&#xff09;&#xff1a;Log in | NVIDIA Developer 根据系统发行版和CUDA版本 (nvcc -V) 选择合适的安装包 EA&#xff08;early access&#xff09;版本代表抢先体验。 GA&#xff08;general availability&#xff09;代…

文件对比工具Beyond Compare 4 mac v4.4.7(28397)中文版

Beyond Compare是一款适用于Windows、Mac OS X和Linux平台的文件和文件夹比较工具。它可以帮助用户比较和同步文件夹、文件和压缩包等内容&#xff0c;支持多种文件格式&#xff0c;如文本、图像、音频、视频等。 软件下载&#xff1a;Beyond Compare 4 mac v4.4.7(28397)中文版…

如何在Node.js中使用定时器

在Node.js中使用定时器是一项常见且重要的任务&#xff0c;特别是在需要执行定时任务或者轮询操作的情况下。Node.js提供了多种方式来实现定时器功能&#xff0c;包括setTimeout、setInterval和setImmediate等方法。本篇博客将介绍如何在Node.js中使用这些定时器&#xff0c;并…

WPF真入门教程30--顺风物流单据管理系统

1、教程回顾 到现在为止&#xff0c;真入门系列教程已完成了29刺由浅入深地讲解&#xff0c;当然不可能讲到了WPF的所有技能点&#xff0c;但读者看到了wpf的内部各种功能及之间的联系&#xff0c;在此基础上&#xff0c;提供一个完整有效的综合项目&#xff0c;本项目采用的是…

期货开户保证金保障市场正常运转

期货保证金是什么&#xff1f;在期货市场上&#xff0c;采取保证金交易制度&#xff0c;投资者只需按期货合约的价值&#xff0c;交一定比率少量资金即可参与期货合约买卖交易&#xff0c;这种资金就是期货保证金。期货保证金&#xff08;以下简称保证金〕按性质与作用的不同。…

AGV搬运机器人能给企业带来哪些效益?

agv 当前物流行业正在以每年40%的速度快速增长&#xff0c;却依然是典型的劳动密集型行业。随着机器人技术的崛起&#xff0c;传统物流行业也开始加大对物流科技设备的研发。AGV机器人被广泛应用于整个仓储系统内&#xff0c;疏解了一部分人力的负担&#xff0c;使后台工作更加…

使用Azure下载数据集方法

首先需要获取到下载的链接&#xff0c;例如&#xff1a; https://aimistanforddatasets01.blob.core.windows.net/cocacoronarycalciumandchestcts-2?sv2019-02-02&src&sigHvhvAtJ7KRr1uIZkjkANqozGvOsqlamMDOKcQegYLrw%3D&st2024-02-29T11%3A55%3A45Z&se2024…

水豚鼠标助手 强大的鼠标美化工具

水豚鼠标助手 水豚鼠标助手是一款 鼠标换肤、屏幕画笔、放大镜、聚光灯、屏幕放大、倒计时功能的强大屏幕演示工具。 软件助手获取 水豚鼠标助手1.0.0 安装教程 第一步&#xff1a;下载后&#xff0c;双击软件安装包 第二步&#xff1a;Windows可能会出现提示弹窗&#xff…

Mac 制作可引导安装器

Mac 使用U盘或移动固态硬盘制作可引导安装器&#xff08;以 Monterey 为例&#xff09; 本教程参考 Apple 官网相关教程 创建可引导 Mac OS 安装器 重新安装 Mac OS 相关名词解释 磁盘分区会将其划分为多个单独的部分&#xff0c;称为分区。分区也称为容器&#xff0c;不同容器…

Docker(运维工具)—— 学习笔记

快速构建、运行、管理应用的工具 一、安装docker 参考Install Docker Engine on Ubuntu | Docker Docs 二、快速入门 1、镜像和容器 docker镜像可以做到忽略操作系统的差异&#xff0c;跨平台运行&#xff0c;忽略安装的差异 当我们利用Docker安装应用时&#xff0c;Dock…

环境配置 |Jupyter lab/Jupyter Notebook 安装与设置

ipynb使用Jupyterlab/Jupyter Notebook 来编写Python程序时的文件,在使用时,可以现转换为标准的.py的python文件 1.Jupyter Lab 1.1.下载安装 环境&#xff1a;Linux pip install jupyterlab 1.2.使用 jupyter lab 点击后进入 1.3.jupyter lab更换内核 因为我的是在anac…

3d图形学基础(一):向量与坐标系

文章目录 1.1 向量与坐标系1.1.1 向量与坐标系的应用1.1.2 完整测试代码 1.1 向量与坐标系 1.1.1 向量与坐标系的应用 零向量&#xff1a; 零向量是没有方向的向量&#xff1b; 负向量&#xff1a; 负向量是与原向量方向相反、长度相等的向量&#xff1b; 向量的模&#xf…