数据元素的有序集合,每个数据元素都有一个到它的下一个元素(有时是它的前一个元素)的链接,假设有一个链表,那么我们需要找到第二小的元素。以下是以下场景。
让我们假设一些简单的输入和输出场景
假设这个场景,我们有一个链表,其中包含的元素是“8->4->6->2->9,”。然后在迭代整个链表之后,第二小的元素是 8。
Input = 8->4->6->2->9
Output = 8
登录后复制
链表的编程实现方式
Node* head = new Node(8);
head->next = new Node(4);
head->next->next = new Node(6);
head->next->next->next = new Node(2);
head->next->next->next->next = new Node(9);
result = solve(head);
登录后复制
考虑另一种情况,链表中的每个元素都具有相同的值。迭代完所有元素后,链表中将找不到第二小的元素。由于链表中的元素每个元素都包含相同的值。
Input = 1->1->1->1->1->1
Output = There is no second smallest element in Linked list
登录后复制
算法
以下是执行任务时应遵循的步骤
-
分配两个变量(S1,S2)
-
S1 将保存链表中最小的元素
-
S2 将保存链表中第二小的元素。
-
每次迭代,最小的元素都会移动到S1,遇到它就移动到S2
-
当最小(S1)小于新的较小值时,新的较小将成为最小(S1)。
-
新的较小的将变得更小(S1),较小的(S1)将移动到第二个较小的(S2)。
-
在每次可能的遍历之后,最终输出中的第二小的元素将作为输出。
示例
在C++实现中,我们可以保留2个变量。 1为最小,other为次小,然后遍历链表,每次遇到更小的元素时,将最小的变量更新到次小,新的较小的就变成最小的。因此,每当一个元素小于最小的元素时,第二小的元素就会变成最小的,最小的元素就会成为新元素。如果不是,我们比较第二小的元素并确定当前元素是否小于第二小的元素,然后进行相应的更新。
#include
using namespace std;
class Node {
public:
int val;
Node *next;
Node(int val) {
this->val = val;
next = NULL;
}
};
int solve(Node* root) {
int s1=root->val, s2=root->val;
while(root) {
if(root->val val;
} else if(root->val val;
}
root = root->next;
}
return s2;
}
int main() {
Node* head = new Node(5);
head->next = new Node(8);
head->next->next = new Node(9);
head->next->next->next = new Node(2);
head->next->next->next->next = new Node(4);
cout