华为OD机试C卷“跳步-数组”Java解答

描述

示例

算法思路1

不断移动数组将元素删去(并未彻底删除,而是将数字元素前移实现“伪删除”)这样删除元素的位置就呈现一定规律,详细见下图(潦草的画)

答案1

import java.util.*;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);System.out.println("请输入一个整数数组,格式为[1,2,3,4,5,6,7,8,9]:");String input = scanner.nextLine();//去除首尾【】,然后以,将字符串分割String [] tokens = input.substring(1,input.length()-1).split(",");//创建整数数组int [] nums = new int[tokens.length];for (int i = 0; i < tokens.length; i++) {nums[i] =Integer.parseInt(tokens[i]) ;//把字符串转换为整数放入nums[]数组中}int jump = scanner.nextInt();int left = scanner.nextInt();System.out.println(sumOfLeft(nums,jump,left));}private static int sumOfLeft(int[] nums, int jump, int left) {int sum = 0;int i=1;int length=nums.length;//记录不断变化的数组长度if(left+jump>length||jump>=length-1) return -1;//剩余数量和跳数和>数组长度则无需跳while(length>left){//nums中剩余个数>left继续跳i=(i+jump)%length;for( int j=i;j<length-1;j++){nums[j]=nums[j+1];}length--;}sum=nums[0]+nums[1]+nums[2];return sum;}
}

详解1

请忽略我这潦草的字体,懒得不想重画了。 

算法思路2

先求整体数组的和,然后不断把删去的元素减去。

答案2

import java.util.*;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);System.out.println("请输入一个整数数组,格式为[1,2,3,4,5,6,7,8,9]:");String input = scanner.nextLine();//去除首尾【】,然后以,将字符串分割String [] tokens = input.substring(1,input.length()-1).split(",");//创建整数数组int [] nums = new int[tokens.length];for (int i = 0; i < tokens.length; i++) {nums[i] =Integer.parseInt(tokens[i]) ;//把字符串转换为整数放入nums[]数组中}int jump = scanner.nextInt();int left = scanner.nextInt();System.out.println(sumOfLeft(nums,jump,left));
//        int [] num={1,2,3,4,5,6,7,8,9};
//        System.out.println(sumOfLeft(num,4,3));}private static int sumOfLeft(int[] nums, int jump, int left) {int sum = 0;int length=nums.length;//记录不断变化的数组长度if(left+jump>length||jump>=length-1) return -1;//剩余数量和跳数和>数组长度则无需跳ArrayList<Integer> numbers = new ArrayList<>();for(int num:nums){sum +=num;numbers.add(num);}for(int i=(1+jump)%numbers.size();numbers.size()>left;i=(i+jump)%numbers.size()){sum -= numbers.get(i);numbers.remove(i);}return sum;}
}

详解2

使用ArrayList集合类实现真正的删除操作。ArrayList详细操作请移步

Java“集合框架”知识速成笔记学完就去实战(三)-CSDN博客

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RabbitMQ - 03 - Work消息模型

目录 部署demo项目 什么是Work消息模型 实现Work消息模型 1.创建队列 2.生产者代码 3.消费者代码 4.配置yml 部署demo项目 通过消息队列demo项目进行练习 相关配置看此贴 http://t.csdnimg.cn/hPk2T 注意 生产者消费者的yml文件也要配置好 什么是Work消息模型 工作…

Java对接腾讯云直播示例

首先是官网的文档地址 云直播 新手指南 可以发现它这个主要是按流量和功能收费的 价格总览 流量这里还只收下行的费用&#xff0c;就是只收观看消耗的流量费 其它的收费就是一些增值业务费 &#xff08;包括直播转码、直播录制、直播截图、直播审核、智能鉴黄、实时监播、移动直…

解决阿里云服务器开启frp服务端,内网服务器开启frp客户端却连接不上的问题

解决方法&#xff1a; 把阿里云自带的Alibabxxxxxxxlinux系统 换成centos 7系统&#xff01;&#xff01;&#xff01;&#xff01; 说一下我的过程和问题&#xff1a;由于我们内网的服务器在校外是不能连接的&#xff0c;因此我弄了个阿里云服务器做内网穿透&#xff0c;所谓…

Sora盈利新路径:基于技术创新与跨界融合

在数字化时代&#xff0c;技术的飞速进步为企业带来了前所未有的盈利机会。Sora作为一款前沿的AI视频生成工具&#xff0c;其盈利新路径可以基于技术创新与跨界融合两个核心策略来探索。 一、技术创新&#xff1a;持续引领行业前沿 Sora学习资料&#xff1a;使用方式完整文档…

安装及管理docker

文章目录 1.Docker介绍2.Docker安装3.免sudo设置4. 使用docker命令5.Images6.运行docker容器7. 管理docker容器8.创建image9.Push Image 1.Docker介绍 Docker 是一个简化在容器中管理应用程序进程的应用程序。容器让你在资源隔离的进程中运行你的应用程序。类似于虚拟机&#…

python基础——条件判断和循环【if,while,for,range】

&#x1f4dd;前言&#xff1a; 这篇文章主要讲解一下条件判断语句if和循环语句while&#xff0c;for在python中需要注意的地方。 建议已有一定了解&#xff08;对语句的执行逻辑清楚&#xff09;的读者观看&#xff0c;如果对条件判断和循环的执行逻辑不太清楚&#xff0c;也可…

【软考】单元测试

目录 1. 概念2. 测试内容2.1 说明2.2 模块接口2.3 局部数据结构2.4 重要的执行路径 3. 测试过程2.1 说明2.2 单元测试环境图2.3 驱动模块2.4 桩模块 4. 模块接口测试与局部数据结构测试的区别 1. 概念 1.单元测试也称为模块测试&#xff0c;在模块编写完成且无编译错误后就可以…

Anaconda prompt运行打开jupyter notebook 指令出错解决方案

一、打不开jupyter notebook网页 报错如下&#xff1a; Traceback (most recent call last): File “D:\anaconda3\lib\site-packages\notebook\traittypes.py”, line 235, in _resolve_classes klass self._resolve_string(klass) File “C:\Users\DELL\AppData\Roaming\Py…

微信小程序-入门

一.通过 Npm方式下载构建 1.下载和安装Npm&#xff1a;Npm https://docs.npmjs.com/downloading-and-installing-node-js-and-npm 或者 https://nodejs.org/en/download/ 未安装npm 提示 以下以安装node安装包为例 按任意键继续 安装完成后 2. 下载和安装小程序开…

腾讯云轻量服务器流量用完了怎么办?还能继续用吗?

腾讯云轻量服务器流量用完了怎么办&#xff1f;超额部分的流量另外支付流量费&#xff0c;流量价格为0.8元/GB&#xff0c;会自动扣你的腾讯云余额&#xff0c;如果你的腾讯云账号余额不足&#xff0c;那么你的轻量应用服务器会面临停机&#xff0c;停机后外网无法访问&#xf…

Spring Security的API Key实现SpringBoot 接口安全

Spring Security的API Key实现SpringBoot 接口安全 Spring Security 提供了各种机制来保护我们的 REST API。其中之一是 API 密钥。API 密钥是客户端在调用 API 调用时提供的令牌。 在本教程中&#xff0c;我们将讨论如何在Spring Security中实现基于API密钥的身份验证。 API…