当前位置: 首页 > news >正文

网站开发需要用例图吗一般的美工可以做网站吗

网站开发需要用例图吗,一般的美工可以做网站吗,Iis wordpress无法发表文章,网站怎么做搜索功能题目:LeetCode 707.设计链表 你可以选择使用单链表或者双链表,设计并实现自己的链表。 单链表中的节点应该具备两个属性:val 和 next 。val 是当前节点的值,next 是指向下一个节点的指针/引用。 如果是双向链表,则还…

题目:LeetCode 707.设计链表

你可以选择使用单链表或者双链表,设计并实现自己的链表。

单链表中的节点应该具备两个属性:val 和 next 。val 是当前节点的值,next 是指向下一个节点的指针/引用。

如果是双向链表,则还需要属性 prev 以指示链表中的上一个节点。假设链表中的所有节点下标从 0 开始。

实现 MyLinkedList 类:

  • MyLinkedList() 初始化 MyLinkedList 对象。
  • int get(int index) 获取链表中下标为 index 的节点的值。如果下标无效,则返回 -1 。
  • void addAtHead(int val) 将一个值为 val 的节点插入到链表中第一个元素之前。在插入完成后,新节点会成为链表的第一个节点。
  • void addAtTail(int val) 将一个值为 val 的节点追加到链表中作为链表的最后一个元素。
  • void addAtIndex(int index, int val) 将一个值为 val 的节点插入到链表中下标为 index 的节点之前。如果 index 等于链表的长度,那么该节点会被追加到链表的末尾。如果 index 比长度更大,该节点将 不会插入 到链表中。
  • void deleteAtIndex(int index) 如果下标有效,则删除链表中下标为 index 的节点。

示例:

输入
["MyLinkedList", "addAtHead", "addAtTail", "addAtIndex", "get", "deleteAtIndex", "get"]
[[], [1], [3], [1, 2], [1], [1], [1]]
输出
[null, null, null, null, 2, null, 3]解释
MyLinkedList myLinkedList = new MyLinkedList();
myLinkedList.addAtHead(1);
myLinkedList.addAtTail(3);
myLinkedList.addAtIndex(1, 2);    // 链表变为 1->2->3
myLinkedList.get(1);              // 返回 2
myLinkedList.deleteAtIndex(1);    // 现在,链表变为 1->3
myLinkedList.get(1);              // 返回 3

初始代码:

class MyLinkedList {public MyLinkedList() {}public int get(int index) {}public void addAtHead(int val) {}public void addAtTail(int val) {}public void addAtIndex(int index, int val) {}public void deleteAtIndex(int index) {}
}/*** Your MyLinkedList object will be instantiated and called as such:* MyLinkedList obj = new MyLinkedList();* int param_1 = obj.get(index);* obj.addAtHead(val);* obj.addAtTail(val);* obj.addAtIndex(index,val);* obj.deleteAtIndex(index);*/

代码:

class ListNode {int val;ListNode next;ListNode(){}ListNode(int val) {this.val = val;}
}class MyLinkedList {int size = 0;ListNode head;public MyLinkedList() {size = 0;head = new ListNode(-1);}public int get(int index) {//下标无效if(index<0||index>=size) return -1;ListNode cur = head.next;while(index > 0) {cur = cur.next;index--;}return cur.val;}public void addAtHead(int val) {ListNode node = new ListNode(val);node.next = head.next;head.next = node;size++;}public void addAtTail(int val) {ListNode node = new ListNode(val);ListNode cur = head;while(cur.next != null) {cur = cur.next;}cur.next = node;size++;}public void addAtIndex(int index, int val) {ListNode node = new ListNode(val);//下标无效if(index<0||index>size) return;if(index == size) {addAtTail(val);return;}ListNode cur = head.next;while(index > 1) {cur = cur.next;index--;}if(index == 0) {node.next = head.next;head.next = node;}else {node.next = cur.next;cur.next = node;}size++;}public void deleteAtIndex(int index) {//下标无效if(index<0||index>=size) return;ListNode cur = head.next;while(index > 1) {cur = cur.next;index--;}if(index == 0) {head.next = head.next.next;}else {cur.next = cur.next.next;}size--;}
}/*** Your MyLinkedList object will be instantiated and called as such:* MyLinkedList obj = new MyLinkedList();* int param_1 = obj.get(index);* obj.addAtHead(val);* obj.addAtTail(val);* obj.addAtIndex(index,val);* obj.deleteAtIndex(index);*/

思考:

这个题又单独定义了ListNode类是我没想到的,然后就是利用带头结点做的整个功能。

在MyLinkedList类中定义了size和head。功能不复杂,还是注意空指针边界。

http://www.yayakq.cn/news/507739/

相关文章:

  • 网站建设优化服务渠道网页设计师培训在哪里
  • 做网站和做软件泉州网上房地产
  • 网站主页设计收费盐城网站建设24gx
  • discuz做资讯网站广西壮族自治区市场监督管理局官网
  • 自己做网站都要什么手续做网站需要有服务器
  • 哪个网站域名便宜科技网站建设+长沙
  • 海珠免费网站建设中职电子商务专业就业方向
  • 运营一个网站要多少钱s上海网站建设
  • 连云港做网站哪里好网站搭建分站需要多少钱
  • 百度提交入口网站网址行业门户网站大全
  • 网站公司维护网站空间多少
  • 做网站多少分辨率好著名的国外设计网站
  • wordpress自定义排版seo网站编辑
  • wordpress评论 ajaxwordpress神马优化
  • 中国建设银行幼儿缴费官网站深互动平台网站
  • 广州车陂网站建设中心怎样免费注册域名
  • 高端品牌鞋子潍坊外贸网站优化
  • 河北中瑞建设集团有限公司网站电子印章制作生成免费
  • 做网站比特币钱包秦皇岛昌黎县建设局网站
  • 扬州网站建设 开元本地工程招标网
  • 陕西省建设监理工程协会网站手机设计软件免费
  • 一般网站开发用什么笔记本东莞如何建网站费用
  • 专业做化学招聘的网站有哪些f式布局网站
  • 网站开发简历项目WordPress底部添加音乐
  • 网盘做电子书下载网站外呼系统电销
  • 如何建立公司网站模块百度 手机网站 收录
  • 怎么改版网站定制软件公司
  • 女性开源网站前端程序员工资一般多少
  • 西安做网站费用站酷设计网站官网未上色文件
  • 海拉尔网站设计android用什么语言开发