文天大人 2020-10-21 18:29 采纳率: 60%
浏览 144

关于java队列中的add与offer的疑问

请问java为什么要设计成两个而不是一个呢?我个人认为一个offer不就可以了吗,当用户实现自己行为的时候,如果发现返回false,则可以自己抛异常,为什么接口要定义一个抛异常的add方法呢?有大佬知道这个设计初衷是什么吗?

  • 写回答

1条回答 默认 最新

  • CSDN-Ada助手 CSDN-AI 官方账号 2022-09-21 03:58
    关注
    不知道你这个问题是否已经解决, 如果还没有解决的话:
    • 文章:剑指offer刷题报告(Java) 中也许有你想要的答案,请看下吧
    • 除此之外, 这篇博客: 剑指offer刷题报告(Java)中的 16.合并两个排序的链表 部分也许能够解决你的问题, 你可以仔细阅读以下内容或者直接跳转源博客中阅读:

      题目:

      //解法:运行时间:27ms 占用内存:9672k
      //递归(还是那句话,感觉链表的题都可以有一种非常简洁的方法做,通常是递归)
      /*
      public class ListNode {
          int val;
          ListNode next = null;
      
          ListNode(int val) {
              this.val = val;
          }
      }*/
      public class Solution {
          public ListNode Merge(ListNode list1,ListNode list2) {
              ListNode head = null;
              if(list1 == null) {
                  return list2;
              } 
              if(list2 == null) {
                  return list1;
              }
              if(list1.val <= list2.val) {
                  head = list1;
                  head.next = Merge(list1.next, list2);
              }
              if(list1.val > list2.val) {
                  head = list2;
                  head.next = Merge(list1, list2.next);
              }
              return head;
          }
      }
      

    如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^
    评论

报告相同问题?

悬赏问题

  • ¥15 在若依框架下实现人脸识别
  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同