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

网站开发的要注意基本原则wordpress头像官网

网站开发的要注意基本原则,wordpress头像官网,东莞住房和城乡建设部网站,一个网站绑定多个域名 卖域名一、题目 现有一链表的头指针 ListNode* pHead,给一定值x,编写一段代码将所有小于x的结点排在其余结点之前,且不能改变原来的数据顺序,返回重新排列后的链表的头指针。 二、思路解析 首先,让我们列出我们需要做的事情&…

一、题目

现有一链表的头指针 ListNode* pHead,给一定值x,编写一段代码将所有小于x的结点排在其余结点之前,且不能改变原来的数据顺序,返回重新排列后的链表的头指针。

二、思路解析

首先,让我们列出我们需要做的事情:

  1. 遍历整个链表;
  2. 对于值小于x的节点,把它们暂时存储起来,并从原链表中删除「删除是为了等下重新插入的时候,不造成元素重复的情况」;
  3. 最后,我们要把这些节点重新插入到链表的头部。

Sounds simple, right? 

Step 1: 选择好用什么结构来存储值小于 x 的元素

这里我采用的是题解区中一位大佬的解法,他是用栈来存储那些待会要头插于链表的、值小于 x 的元素的。

我们首先定义一个栈来存储所有小于x的节点的值。

如果你对栈不熟悉,没关系,想象一下你在吃饭时堆放碗筷的样子,最后放上去的碗筷总是最先被取走,栈就是这样工作的。

Step 2: 遍历链表

 遍历过程,如果我们遇到一个值小于x的节点,我们就把它的值压入栈中,并从原链表中删除这个节点。

如何删除节点,只需要把它前面节点的 next 指针指向它的下一个节点即可。

Step 3: 把栈中元素用头插法,插入链表

在我们遍历完链表后,所有小于x的节点都已经被保存在了栈中,而由于栈的先进后出特性,我们可以保证最早被删除的节点最后被添加回链表。

因此,我们从栈顶开始,每次弹出一个节点,然后创建一个新的节点,并将其添加到链表的头部。这样,我们就可以保证节点的原始顺序被保持。

这就是这道题的完整解题思路啦,下面请看完整代码~

三、完整代码

import java.util.*;/*
public class ListNode {int val;ListNode next = null;ListNode(int val) {this.val = val;}
}*/public class Partition {public ListNode partition(ListNode pHead, int x) {// write code hereif(pHead == null){return null;}Stack<Integer> stack = new Stack<>();ListNode cur = pHead;ListNode prev = null;while(cur != null){if(cur.val < x){stack.add(cur.val);if(cur == pHead){pHead = pHead.next;cur = pHead;}else{cur = cur.next;prev.next = cur;}}else{prev = cur;cur = cur.next;}}while(!stack.isEmpty()){ListNode newNode = new ListNode(stack.pop());newNode.next = pHead;pHead = newNode;}return pHead;}
}

以上就是本篇博客的全部内容啦,如有不足之处,还请各位指出,期待能和各位一起进步!

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

相关文章:

  • 如何做更改网站的图片微信网站备案
  • 外贸手机商城网站建设 深圳做哪种网站赚钱
  • 西安 网站 制作怎么做网络推广赚佣金
  • 新乡彩票网站建设重庆有没有做网站的
  • 网站建设与会展wordpress 添加关键词
  • 太原手手工网站建设公司建设大马路小学网站
  • 连云港网站关键词wordpress 模板选择器
  • wordpress生活插件昆明网络优化
  • 专做脚本的网站南京响应式网站建设
  • 北京网站建设加q.479185700北京计算机编程培训学校
  • 丰润网站建设电子商务公司的名字
  • 完整个人网站html成都专业的网站建站公司
  • 企业网站主题Sensei wordpress插件
  • 企业做网站的步骤与做网站注意事项wordpress idc模板
  • 商城类型的网站怎么做有了网站怎么做app
  • 购物型网站榆次网站建设公司
  • 南宁做网站推广网站建设更新
  • 大连装修网站推广dw旅游网站模板
  • 公司网站手工优化怎么做学校门户网站功能
  • 外贸英文网站搭建的公司网站建设感恩
  • 浦项建设内部网站青岛网站建设策划
  • 电子商务网站建设组织流程图顺德水利和国土建设局网站
  • 网站建设研究意义网站建设yankt
  • 网站开发总出现出现404赤壁网站建设公司
  • 做湲兔费网站视颍开发一个微信小程序价格
  • 如何设计网站域名微信支付开发文档
  • 大型电商网站开发价格简单网站的制作
  • 湖南兼职网站建设香河住房与建设局网站
  • 购买域名后怎么建网站先建网站还是先做app好
  • 网站推广seo是什么不要验证码的广告网站