通过在每个位置选择最大元素,从两个链表创建一个链表
给定两个相同大小的链表,任务是使用这些链表创建新的链表,其中在每一步中,选择两个链表中的两个元素中的最大值,并跳过另一个。
例子:
Input:
list1 = 5 -> 2 -> 3 -> 8 -> NULL
list2 = 1 -> 7 -> 4 -> 5 -> NULL
Output: 5 -> 7 -> 4 -> 8 -> NULL
Input:
list1 = 2 -> 8 -> 9 -> 3 -> NULL
list2 = 5 -> 3 -> 6 -> 4 -> NULL
Output: 5 -> 8 -> 9 -> 4 -> NULL
方法:我们同时遍历两个链表并比较两个链表中的节点。其中较大的节点将被添加到新的链表中。我们对每个节点都这样做,然后打印生成的链表的节点。
下面是上述方法的实现:
C++
// C++ implementation of the approach
#include
using namespace std;
// Representation of node
struct Node {
int data;
Node* next;
};
// Function to insert node in a linked list
void insert(Node** root, int item)
{
Node *ptr, *temp;
temp = new Node;
temp->data = item;
temp->next = NULL;
if (*root == NULL)
*root = temp;
else {
ptr = *root;
while (ptr->next != NULL)
ptr = ptr->next;
ptr->next = temp;
}
}
// Function to print the
// nodes of a linked list
void display(Node* root)
{
while (root != NULL) {
cout << root->data << " -> ";
root = root->next;
}
cout << "NULL";
}
// Function to generate the required
// linked list and return its head
Node* newList(Node* root1, Node* root2)
{
Node *ptr1 = root1, *ptr2 = root2;
Node* root = NULL;
// While there are nodes left
while (ptr1 != NULL) {
// Maximum node at current position
int currMax = ((ptr1->data < ptr2->data)
? ptr2->data
: ptr1->data);
// If current node is the first node
// of the newly linked list being
// generated then assign it to the root
if (root == NULL) {
Node* temp = new Node;
temp->data = currMax;
temp->next = NULL;
root = temp;
}
// Else insert the newly
// created node in the end
else {
insert(&root, currMax);
}
// Get to the next nodes
ptr1 = ptr1->next;
ptr2 = ptr2->next;
}
// Return the head of the
// generated linked list
return root;
}
// Driver code
int main()
{
Node *root1 = NULL, *root2 = NULL, *root = NULL;
// First linked list
insert(&root1, 5);
insert(&root1, 2);
insert(&root1, 3);
insert(&root1, 8);
// Second linked list
insert(&root2, 1);
insert(&root2, 7);
insert(&root2, 4);
insert(&root2, 5);
// Generate the new linked list
// and get its head
root = newList(root1, root2);
// Display the nodes of the generated list
display(root);
return 0;
}
Java
// Java implementation of the approach
import java.util.*;
class GFG
{
// Representation of node
static class Node
{
int data;
Node next;
};
// Function to insert node in a linked list
static Node insert(Node root, int item)
{
Node ptr, temp;
temp = new Node();
temp.data = item;
temp.next = null;
if (root == null)
root = temp;
else
{
ptr = root;
while (ptr.next != null)
ptr = ptr.next;
ptr.next = temp;
}
return root;
}
// Function to print the
// nodes of a linked list
static void display(Node root)
{
while (root != null)
{
System.out.print( root.data + " - > ");
root = root.next;
}
System.out.print("null");
}
// Function to generate the required
// linked list and return its head
static Node newList(Node root1, Node root2)
{
Node ptr1 = root1, ptr2 = root2;
Node root = null;
// While there are nodes left
while (ptr1 != null)
{
// Maximum node at current position
int currMax = ((ptr1.data < ptr2.data)
? ptr2.data
: ptr1.data);
// If current node is the first node
// of the newly linked list being
// generated then assign it to the root
if (root == null)
{
Node temp = new Node();
temp.data = currMax;
temp.next = null;
root = temp;
}
// Else insert the newly
// created node in the end
else
{
root = insert(root, currMax);
}
// Get to the next nodes
ptr1 = ptr1.next;
ptr2 = ptr2.next;
}
// Return the head of the
// generated linked list
return root;
}
// Driver code
public static void main(String args[])
{
Node root1 = null, root2 = null, root = null;
// First linked list
root1 = insert(root1, 5);
root1 = insert(root1, 2);
root1 = insert(root1, 3);
root1 = insert(root1, 8);
// Second linked list
root2 = insert(root2, 1);
root2 = insert(root2, 7);
root2 = insert(root2, 4);
root2 = insert(root2, 5);
// Generate the new linked list
// and get its head
root = newList(root1, root2);
// Display the nodes of the generated list
display(root);
}
}
// This code is contributed by Arnab Kundu
Python3
# Python3 implementation of the approach
import math
# Representation of node
class Node:
def __init__(self, data):
self.data = data
self.next = None
# Function to insert node in a linked list
def insert(root, item):
#ptr, *temp
temp = Node(item)
temp.data = item
temp.next = None
if (root == None):
root = temp
else:
ptr = root
while (ptr.next != None):
ptr = ptr.next
ptr.next = temp
return root
# Function to print the
# nodes of a linked list
def display(root):
while (root != None) :
print(root.data, end = "->")
root = root.next
print("NULL")
# Function to generate the required
# linked list and return its head
def newList(root1, root2):
ptr1 = root1
ptr2 = root2
root = None
# While there are nodes left
while (ptr1 != None) :
# Maximum node at current position
currMax = ((ptr1.data < ptr2.data) and
ptr2.data or ptr1.data)
# If current node is the first node
# of the newly linked list being
# generated then assign it to the root
if (root == None):
temp = Node(currMax)
temp.data = currMax
temp.next = None
root = temp
# Else insert the newly
# created node in the end
else :
root = insert(root, currMax)
# Get to the next nodes
ptr1 = ptr1.next
ptr2 = ptr2.next
# Return the head of the
# generated linked list
return root
# Driver code
if __name__=='__main__':
root1 = None
root2 = None
root = None
# First linked list
root1 = insert(root1, 5)
root1 = insert(root1, 2)
root1 = insert(root1, 3)
root1 = insert(root1, 8)
# Second linked list
root2 = insert(root2, 1)
root2 = insert(root2, 7)
root2 = insert(root2, 4)
root2 = insert(root2, 5)
# Generate the new linked list
# and get its head
root = newList(root1, root2)
# Display the nodes of the generated list
display(root)
# This code is contributed by Srathore
C#
// C# implementation of the approach
using System;
class GFG
{
// Representation of node
public class Node
{
public int data;
public Node next;
};
// Function to insert node in a linked list
static Node insert(Node root, int item)
{
Node ptr, temp;
temp = new Node();
temp.data = item;
temp.next = null;
if (root == null)
root = temp;
else
{
ptr = root;
while (ptr.next != null)
ptr = ptr.next;
ptr.next = temp;
}
return root;
}
// Function to print the
// nodes of a linked list
static void display(Node root)
{
while (root != null)
{
Console.Write( root.data + " - > ");
root = root.next;
}
Console.Write("null");
}
// Function to generate the required
// linked list and return its head
static Node newList(Node root1, Node root2)
{
Node ptr1 = root1, ptr2 = root2;
Node root = null;
// While there are nodes left
while (ptr1 != null)
{
// Maximum node at current position
int currMax = ((ptr1.data < ptr2.data)
? ptr2.data
: ptr1.data);
// If current node is the first node
// of the newly linked list being
// generated then assign it to the root
if (root == null)
{
Node temp = new Node();
temp.data = currMax;
temp.next = null;
root = temp;
}
// Else insert the newly
// created node in the end
else
{
root = insert(root, currMax);
}
// Get to the next nodes
ptr1 = ptr1.next;
ptr2 = ptr2.next;
}
// Return the head of the
// generated linked list
return root;
}
// Driver code
public static void Main(String []args)
{
Node root1 = null, root2 = null, root = null;
// First linked list
root1 = insert(root1, 5);
root1 = insert(root1, 2);
root1 = insert(root1, 3);
root1 = insert(root1, 8);
// Second linked list
root2 = insert(root2, 1);
root2 = insert(root2, 7);
root2 = insert(root2, 4);
root2 = insert(root2, 5);
// Generate the new linked list
// and get its head
root = newList(root1, root2);
// Display the nodes of the generated list
display(root);
}
}
/* This code contributed by PrinciRaj1992 */
Javascript
输出:
5 -> 7 -> 4 -> 8 -> NULL
如果您希望与专家一起参加现场课程,请参阅DSA 现场工作专业课程和学生竞争性编程现场课程。