码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • (Java实现) HDOJ 1051 Wooden Sticks 贪心算法


    Problem Description

    (a)第一根木材的安装时间是1分钟

    (b)在处理完长度为l,宽度为w的木材后,若紧接着处理的木材长度l'>l且w'>w,则不需要安装时间,否则需1分钟安装时间

    (c)找出最短安装时间的序列对

    解决思路:

    1.根据木材数n创建对应的n个木材对象,初始化其长度和宽度

    2.将所有木材以长度升序排列(当长度相等时,宽度宽的排在后面)

    3.调整机器安装时间(time++),处理排列后方未被处理的长度更长,宽度更宽,即无需安装时间的木材,将该木材标志为已处理

    4.从木材1到木材n循环执行步骤3

    import java.util.Arrays;
    import java.util.Scanner;
    
    public class Main {
    
    public static void main(String[] args) {
    Scanner in = new Scanner(System.in);
    int a = in.nextInt();
    for(int i = 0; i < a; i++){
    int n = in.nextInt();   //木头数
    Wood[] woods = new Wood[n];
    for(int j = 0; j < n; j++){
    woods[j] = new Wood(in.nextInt(),in.nextInt());
    }
    Arrays.sort(woods);
    
    int time = 0;
    int nl,nw;
    for(int k = 0; k = nw && woods[j].judge == 0){
    nl = woods[j].l;
    nw = woods[j].w;
    woods[j].setJ();   
    }
    }
    }
    System.out.println(time);
    
    }
    
    }
    
    
    }
    
    //木材类
    class Wood implements Comparable{
    int l;
    int w;
    int judge = 0;   //木材是否已被处理
    public Wood(int l,int w){
    this.l = l;
    this.w = w;
    }
    //将木材设置为已处理
    public void setJ(){
    this.judge = 1;
    }
    
    //重写比较方法
    @Override
    public int compareTo(Wood wood) {
    //考虑到长度相等的情况
    if(l == wood.l){
    return (w > wood.w)? 1:-1;
    }
    return (l > wood.l)? 1:-1;
    }
    
    }
  • 相关阅读:
    回顾封装、继承和多态的概念,并给出相关示例
    Qt学习笔记详解(1)- 对象树与信号与槽
    Linux 完整 Redis 安装配置教程(可用远程连接)
    Overmind VS Redux
    javascript的讲解
    LeetcodeTop100 (30) 随机链表复制
    JavaScript中的数据类型(笔记,略许潦草,不建议观看)
    MATLAB非矩形区域上曲面的绘制
    设计模式-代理模式(Proxy)
    依赖范围,生命周期与插件
  • 原文地址:https://blog.csdn.net/weixin_71792169/article/details/128145319
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号