将单向链表按某值划分成左边小、中间相等、右边大的形式

步骤

1.遍历数组得到长度
2 生成长度为N的链表数组,遍历链表将节点放入数组内
3 针对链表数组进行快排partition
4将调整过的链表数组再维护成一个链表即可

#include"stdafx.h"
#include<iostream>
#include<vector>

using namespace std;

struct ListNode
{
	int val;
	ListNode*next;
	ListNode(int x) :val(x), next(NULL) {}
};
void swap(vector<ListNode*>&arr, int l, int r)
{
	int temp = arr[l]->val;
	arr[l]->val = arr[r]->val;
	arr[r]->val = temp;
}
void arrPartition(vector<ListNode*>&arr, int pivot)
{
	int small = -1;
	int big = arr.size();
	int index = 0;
	while (index < big)
	{
		if (arr[index]->val <pivot)
		{
			swap(arr, ++small, index++);
		}
		else if (arr[index]->val>pivot)
		{
			swap(arr, --big, index);
		}
		else
		{
			index++;
		}
	}
}
ListNode*listPartition(ListNode*head, int pivot)
{
	
	if (head == NULL) return head;
	ListNode*cur = head;
	int i = 0;
	while (cur != NULL)
	{
		cur = cur->next;
		i++;
	}
	vector<ListNode*>res(i);
	i = 0;
	cur = head;
	for (i = 0; i < res.size(); i++)
	{
		res[i] = cur;
		cur = cur->next;
	}
	arrPartition(res, pivot);
	for (int i = 1; i < res.size() ; i++)
	{
		res[i-1]->next = res[i];
	}
	res[i-1]->next = NULL;
	return res[0];

    
}
int main()
{
	ListNode*l1 = new ListNode(11);
	l1->next = new ListNode(10);
	l1->next->next = new ListNode(11);
	l1->next->next->next = new ListNode(12);
	l1->next->next->next ->next= new ListNode(7);
	ListNode*l2 = new ListNode(9);
	l2->next = new ListNode(10);
	l2->next->next = new ListNode(11);
	l2->next->next->next = new ListNode(12);
	listPartition(l1, 11);
	
	while (l1!= NULL)
	{
		cout << l1->val << endl;
		l1 = l1->next;
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是建立单向链表并按整数从大到小排序的 C++ 代码示例: ```c++ #include <iostream> using namespace std; struct ListNode { int val; ListNode* next; ListNode(int x) : val(x), next(NULL) {} }; ListNode* insertNode(ListNode* head, int val) { ListNode* newNode = new ListNode(val); if (head == NULL) { return newNode; } if (val > head->val) { newNode->next = head; return newNode; } ListNode* cur = head; while (cur->next != NULL && cur->next->val > val) { cur = cur->next; } newNode->next = cur->next; cur->next = newNode; return head; } ListNode* sortList(ListNode* head) { ListNode* newHead = NULL; ListNode* cur = head; while (cur != NULL) { ListNode* next = cur->next; newHead = insertNode(newHead, cur->val); cur = next; } return newHead; } void printList(ListNode* head) { while (head != NULL) { cout << head->val << " "; head = head->next; } cout << endl; } int main() { ListNode* head = NULL; head = insertNode(head, 3); head = insertNode(head, 1); head = insertNode(head, 5); head = insertNode(head, 2); printList(head); head = sortList(head); printList(head); return 0; } ``` 在此示例中,我们定义了一个 `ListNode` 结构体来表示链表节点,包含一个整数值 `val` 和一个指向下一个节点的指针 `next`。`insertNode` 函数用于将一个新节点插入到链表中,按整数从大到小排序。`sortList` 函数遍历原链表,将每个节点插入到新链表中,最终返回新链表的头节点。`printList` 函数用于打印链表中的所有节点值。 在 `main` 函数中,我们创建一个空链表,然后依次插入节点 3、1、5、2,打印原链表并排序后再次打印链表。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值