纪念品分组java_纪念品分组 ——易懂、简介、技巧(Java代码)

我的思路:

1、先排序

2、两层循环嵌套,外面的一层从数组末尾开始,里面一层从头开始遍历,首先满足的条件就是这两个数都不能是 NULL 的,并且两个物品的价值加起来不大于最大价值,都满足之后就把两个物品都赋值为 NULL 表示能放入同一个组,sum + 1 计数并跳出循环,因为都为空了表示里面循环没必要继续进行下去;

3、当里面的循环遍历完成以后需要进行判断,因为有可能当里面的循环遍历之后没有能和它匹配的那么就只能把当前分一个组,赋值为 NULL 并 sum+1。

#####算是比较简洁的过程,思路也比较简单

public class Test {

public static void main(String[] args) {

Scanner sc = new Scanner(System.in);

int max = sc.nextInt();

int num = sc.nextInt();

//创建数组保存值

Integer[] arr = new Integer[num];

for (int i = 0; i < num; i++) {

arr[i] = sc.nextInt();

}

//排序

Arrays.sort(arr);

int sum = 0;

//外层循环

for (int i = arr.length - 1; i >= 0; i--) {

//内层循环

for (int j = 0; j < arr.length; j++) {

//两个值都不为空并且两个值加起来不大于最大值

if (arr[j] != null && arr[i] != null && arr[i] + arr[j] <= max) {

arr[i] = null;

arr[j] = null;

sum++;

break;

}

}

//如果没有匹配的值就单独分一组

if(arr[i] != null) {

arr[i] = null;

sum++;

}

}

System.out.println(sum);

}

}

0.0分

1 人评分

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

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

相关文章

java生命小游戏_Java修炼——飞机生存小游戏

在学习了java入门的课程之后&#xff0c;自己动手跟着老师写的一个小游戏&#xff0c;用的是Frame。总共有七个类。1.飞机游戏的主窗口(MyGameFrame)继承Frame。package com.bjsxt.plane;import java.awt.Color;import java.awt.Font;import java.awt.Frame;import java.awt.Gr…

java 线程类 通信_Java 中利用管道实现线程间的通讯

在Java 语言中&#xff0c;提供了各种各样的输入输出流(stream),使我们能够很方便的对数据进行操作&#xff0c;其中&#xff0c;管道(pipe)流是一种特殊的流&#xff0c;用于在不同线程(threads)间直接传送数据。一个线程发送数据到输出管道&#xff0c;另一个线程从输入管道中…

java整型缓存_JAVA整型包装类的缓存策略

Java Integer的缓存策略public classJavaIntegerCache {public static voidmain(String... strings) {Integer integer1 3;Integer integer2 3;if (integer1 integer2)System.out.println("integer1 integer2");elseSystem.out.println("integer1 ! integer2&q…

java年利润编程题_[编程入门]利润计算-题解(Java代码)

![](/image_editor_upload/20200216102044_14158.png)这也是简单的分类问题&#xff0c;用if进行分类后就可以用switch进行分类计算利润代码如下&#xff1a;package javaapplication;import java.util.Scanner;public class JavaApplication{public static void main(String[]…

java面向方面编程_面向方面编程的介绍----基本概念

面向对象的编程中常用的概念是&#xff1a;继承、封装、多态。在面向方面的编程中常使用的概念是&#xff1a;advices/interceptors, introductions, metadata, and pointcuts。AOP 面向方面编程的介绍----基本概念(3)面向方面的编程思路很简单。从面向过程、函数的编程到面向对…

链队列的基本运算java_链式队列基本操作的实现问题

问题描述&#xff1a;用链式存储方式实现队列的基本操作涉及变量&#xff1a;front&#xff1a;Node型自定义变量&#xff0c;指向队首元素rear&#xff1a;Node型自定义变量&#xff0c;指向队尾元素涉及教材&#xff1a;《数据结构——Java语言描述(第2版)》 清华大学出版社大…

mysql数据库优化看的书_MySQL 数据库优化,看这篇就够了

点击上方"IT牧场"&#xff0c;选择"设为星标"技术干货每日送达&#xff01;来源&#xff1a;segmentfault.com/a/1190000018631870前言数据库优化一方面是找出系统的瓶颈,提高MySQL数据库的整体性能,而另一方面需要合理的结构设计和参数调整,以提高用户的相…

python 升级所有库_自动更新Python所有第三方库

一般python用得比较久以后&#xff0c;就会安装很多第三方的库。比如这是我的pip list情况&#xff1a;pip list而且一屏还显示不完。通过如下命令可以看到需要更新的第三方库&#xff1a;pip list -o需要更新的库而pip提供的更新命令只能一个个的更新...pip install -U 库名 #…

java kryo register_java相关:Kryo框架使用方法代码示例

java相关&#xff1a;Kryo框架使用方法代码示例发布于 2021-1-21|复制链接摘记: Kryo框架的source已移至https://github.com/EsotericSoftware/kryo &#xff0c;进入此页面&#xff0c;然后点击右边的Download Zip按钮&#xff0c;就能下载到最新版本的Kr ..Kryo框架的source已…

java 反射 类变量_java反射机制取出model类的所有变量,以及value

工作上遇到个问题,顺便解决了,希望对大家有帮助package com.zuidaima.util;public static void main(String[] args) throws ClassNotFoundException, IllegalArgumentException, IllegalAccessException, InstantiationException {Class> obj Class.forName("com.roi…

php 去掉不可见字符串,php去掉指定字符串的办法

php去掉指定字符串的办法&#xff1a;首先创建一个PHP示例文件&#xff1b;然后定义字符串&#xff1b;最后通过“str_replace(array("_","",""),"",$str);”方法去掉指定字符串即可。推荐&#xff1a;《PHP视频教程》用正则可以解决问…

php开发地图导航,php 实现百度地图(很详细出来的地图)

百度地图搜索--leyangjunvar map new BMap.Map("container");map.centerAndZoom(new BMap.Point(116.404, 39.915), 11);var local new BMap.LocalSearch(map, {renderOptions: {map: map, panel: "results"}});var opts {anchor: BMAP_ANCHOR_TOP_RIGH…

php查询表导出excel文件路径,Thinkphp5如何将导出的excel表格存储到服务器中项目目录的指定目录中?...

/**excel表格导出param string $fileName 文件名称param array $headArr 表头名称param array $data 要导出的数据author static7 */function excelExport($fileName , $headArr [], $data []) {$fileName . "_" . date("Y_m_d", Request::instance()-&…

php 大型系统开法流程图,有一个php项目源码,如何搞清楚执行过程?画出其流程图...

比如一个c项目&#xff0c;可以让其运行起来&#xff0c;然后利用gdb调试&#xff0c;一步步执行&#xff0c;搞清楚其执行过程&#xff0c;那么一个php项目&#xff0c;如何才能搞清楚执行过程呢&#xff0c;或者需要什么专业的工具如果你想调试的话&#xff0c;可以使用zend …

php如何判断文件的内容,php 判断文件内容是否存在的方法

php 判断文件是否存在的示例代码本篇内容为大家讲解的是php 判断文件是否存在&#xff0c;感兴趣的同学参考学习下&#xff0c;本文内容如下:sha1_file 计算文本文件SHA-1散列# 计算文本文件 $file 的 SHA-1 散列&#xff1a;sha1_file($file);# 语法sha1_file(file,raw)# 参数…

php文件上传并保存路径到数据库,thinkphp表单上传文件并将文件路径保存到数据库中?...

上传单个文件&#xff0c;此文以上传图片为例&#xff0c;上传效果如图所示创建数据库upload_img,用于保存上传路径CREATE TABLE seminar_upload_img ( id int(11) NOT NULL AUTO_INCREMENT, img_name varchar(255) DEFAULT NULL COMMENT 图片名称, img_url varchar(255) DE…

PHP数组的访问方法有几种,数组常用方法有哪些

数组中常用的方法有&#xff1a;1、给数组末尾添加新内容的push方法&#xff1b;2、删除数组最后一项的pop方法&#xff1b;3、删除数组第一项的shift方法&#xff1b;4、向数组首位添加新内容unshift方法等等。数组常用的一些方法&#xff1a;1、push()向数组的末尾添加新内容…

roaringbitmap java,roaringbitmap 源码解析 bitmap add过程

最近在做标签平台的分析引擎。底层涉及到位图的处理&#xff0c;所以涉及到roaringbitmap。

java opcode 反汇编,如何将VM的opcode嵌入汇编源码中

这次来一个关于VM的混淆办法&#xff0c;可能只是个小trick&#xff0c;仅仅来自胡思乱想也许你会觉得很奇怪&#xff0c;一个VM能有啥新鲜的&#xff0c;对&#xff0c;单纯来说VM保护源代码已经非常的成熟了&#xff0c;所以在这里只做最基本的介绍&#xff0c;而且这次的重点…

php ip 合法,什么是合法ip地址

合法的IP地址中&#xff0c;每个三位数都是在0~254之间的&#xff0c;不可能是大于254就连255都不行。这才是合法的IP地址&#xff0c;还有 IP地址有A\B\C类IP。iPv4的ip地址都是(1~255).(0~255).(0~255).(0~255)的格式。A类的IP地址范围为0.0.0.0-127.255.255.255B类的IP地址范…