vivo 部分链表反转
方法一:使用栈交换需要反转的数字
#include <iostream>
#include <stack>
#include "list.h"
using namespace std; void partreverse(ListNode* phead, int m, int n)
{
int count = 1;
ListNode* p = phead;
stack<ListNode*> s1;
if (m < 1 || n < 1)
return;
if (m > n)
{//保证m小于n
int temp = m;
m = n;
n = temp;
}
if (m == n)//两者相等不交换直接返回
return;
while (count < m && p != nullptr)
{
count++;
p = p->m_pNext;
}
ListNode* start = p;
int estart = m + (n - m) / 2 + 1;
while (count <n && p != nullptr)
{
count++;
p = p->m_pNext;
if (count >= estart)
{
if (p != nullptr)
s1.push(p);//后半部分进栈
else
return;//超出长度直接返回
}
}
while (!s1.empty())
{//依次交换
ListNode* cur = s1.top();
int temp = cur->m_nValue;
cur->m_nValue = start->m_nValue;
start->m_nValue = temp;
s1.pop();
start = start->m_pNext;
}
return;
} void Test1()
{
ListNode* pNode1 = CreateListNode(1);
ListNode* pNode2 = CreateListNode(2);
ListNode* pNode3 = CreateListNode(3);
ListNode* pNode4 = CreateListNode(4);
ListNode* pNode5 = CreateListNode(5); ConnectListNodes(pNode1, pNode2);
ConnectListNodes(pNode2, pNode3);
ConnectListNodes(pNode3, pNode4);
ConnectListNodes(pNode4, pNode5); PrintList(pNode1);
partreverse(pNode1, 2, 4);
PrintList(pNode1);
} int main(int argc, char* argv[])
{
Test1();
return 0;
}
方法二:直接反转需要反转的部分
#include <iostream>
#include "list.h"
using namespace std; void partreverse(ListNode* phead, int m, int n)
{
int count = ;
ListNode* p = phead;
if (m < || n < )
return;
if (m > n)
{//保证m小于n
int temp = m;
m = n;
n = temp;
}
if (m == n)//两者相等不交换直接返回
return;
while (count < m- && p != nullptr)
{
count++;
p = p->m_pNext;
}
ListNode* prev = p, *start = phead, *end = nullptr, *next = nullptr;
if (m == )
prev = nullptr;
if (prev != nullptr)
start = prev->m_pNext;
p = start;
for (count = m; count < n && p != nullptr;)
{
count++;
p = p->m_pNext;
}
end = p;
if (end != nullptr)
next = end->m_pNext;
else
return;//end为nullptr,超出链表长度
if(prev !=nullptr)
prev->m_pNext = end;//prev指向反转后的链表头
end->m_pNext = nullptr;
ListNode* rprve = start, *rcur = start->m_pNext, *rnext = rcur->m_pNext;
while (rcur != end)
{//指定范围内的链表反转
rcur->m_pNext = rprve;
rprve = rcur;
rcur = rnext;
if (rnext != nullptr)
rnext = rnext->m_pNext;
}
rcur->m_pNext = rprve;
start->m_pNext = next;
if (prev == nullptr)
phead = end;//链表头被反转
PrintList(phead);
return; } void Test1()
{
ListNode* pNode1 = CreateListNode();
ListNode* pNode2 = CreateListNode();
ListNode* pNode3 = CreateListNode();
ListNode* pNode4 = CreateListNode();
ListNode* pNode5 = CreateListNode(); ConnectListNodes(pNode1, pNode2);
ConnectListNodes(pNode2, pNode3);
ConnectListNodes(pNode3, pNode4);
ConnectListNodes(pNode4, pNode5); PrintList(pNode1);
partreverse(pNode1, , );
//PrintList(pNode1);
} int main(int argc, char* argv[])
{
Test1();
return ;
}
前面花太多时间导致后面的送分题01背包没时间做,我恨!
vivo 部分链表反转的更多相关文章
- 链表反转leetcode206
最近准备结束自己的科研生涯,准备要开始找工作了,准备在LEETCODE刷刷题...刷的前40题全部用python刷的,各种调包速度奇快,后被师哥告知这样没意义,于是准备开始回归C++,Python用的 ...
- 链表反转 (Multi-method)
链表反转是链表相关问题最基础的知识,做完LeetCode中LinkedList后才会有这种体会,因为ACM算法中不会涉及这一部分.解决这一问题有多种方法,在面试中面试官通常也会要求写出多种.包括sta ...
- java实现单链表反转
一.简介 经查阅,主要有两种方法实现链表反转,递归反转法和遍历反转法: 递归: 在反转当前结点之前先反转其后边的结点,即.从尾结点开始逆向反转各个节点的指针域指向: 遍历:从前往后反转各个结点的指针域 ...
- C++ 单向链表反转
单向链表反转,一道常见的面试题,动手实现下. #include "stdafx.h" #include <stdlib.h> struct Node{ int data ...
- c语言:链表排序, 链表反转
下面将实现链表排序的排序和遍历显示功能: 所定义的链表结构如下: head -> p1 -> p2 ->p3 ->....->pn; head的本身不作为数据节点,hea ...
- 【Java数据结构】Java数据结构之链表反转
我们都知道用C可以很简单的实现单链表反转,今天来学习下,在Java中如何实现链表反转. 思路很简单,定义一个类,这个类分成2块,一块是表示自身的标志,另外一个存储指向下一个元素的引用.通过互换相邻两个 ...
- [LeetCode] 链表反转相关题目
暂时接触到LeetCode上与链表反转相关的题目一共有3道,在这篇博文里面总结一下.首先要讲一下我一开始思考的误区:链表的反转,不是改变节点的位置,而是改变每一个节点next指针的指向. 下面直接看看 ...
- 单链表反转(Singly Linked Lists in Java)
单链表反转(Singly Linked Lists in Java) 博客分类: 数据结构及算法 package dsa.linkedlist; public class Node<E> ...
- 【easy】206. Reverse Linked List 链表反转
链表反转,一发成功~ /** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; ...
随机推荐
- CentOS下配置Apache HTTPS
一.安装Apache支持SSL/TLS yum install mod_ssl openssl 二.创建证书 证书(Cerificate)的基本作用是将一个公钥和安全个体(个人.公司.组织等)的名字绑 ...
- 使用Servlet实现验证码
没有验证码带来的问题 对特定用户不断登录破解密码. 对某个网站创建账户. 对某个网站提交垃圾数据. 对某个网站刷票. 通过验证码由用户肉眼识别其中的验证码信息,从而区分用户是人还是计算机. 定义: ...
- HTTP 缓存简单了解
HTTP 缓存简单了解.文章整理了相关资料,记录了部分实践.方便大家轻松了解缓存.能回答上三个问题,HTTP缓存就算理解呢.能否缓存?缓存是否过期?协商缓存? 概要: web缓存 缓存的处理 前端解决 ...
- ipcclean - 从退出的PostgreSQL服务器中删除共享内存和信号灯
SYNOPSIS ipcclean DESCRIPTION 描述 ipcclean 删除当前用户拥有的所有共享内存段和信号灯集. 它的目地是在 PostgreSQL 服务器 (postmaster(1 ...
- [转]实际项目中如何使用Git做分支管理 (A successful Git branching model)
来自 https://nvie.com/posts/a-successful-git-branching-model/ In this post I present the development m ...
- CentOS 7.4 下安装部署Nagios监控系统详细攻略(三)
Nagios是一个流行的电脑系统和网络监控程序,它检测主机和服务,当异常发生和解除时能提醒用户.它是基于GPLv2开发的开源软件,可免费获得及使用. nagios工作原理 nagios的功能是监控服务 ...
- PAT Basic 1029 旧键盘 (20 分)
旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现.现在给出应该输入的一段文字.以及实际被输入的文字,请你列出肯定坏掉的那些键. 输入格式: 输入在 2 行中分别给出应该输入的文字.以及 ...
- 2019牛客暑期多校训练营(第一场) A Equivalent Prefixes ( st 表 + 二分+分治)
链接:https://ac.nowcoder.com/acm/contest/881/A 来源:牛客网 Equivalent Prefixes 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/ ...
- python 类的成员及继承
1. @staticmethod 静态方法 静态方法不能访问实例变量和类变量,除了身处类里面,所以只能通过类调用以外,它其实和类没有什么关系.如果想要用它访问实例变量或类变量,需要把实例和类传递给函数 ...
- 查看系统的DPI
#include <Windows.h> #include <iostream> int main() { SetProcessDpiAwarenessContext(DPI_ ...