C++程序:在链表中找到第二小的元素

2023年 8月 27日 62.4k 0

C++程序:在链表中找到第二小的元素

数据元素的有序集合,每个数据元素都有一个到它的下一个元素(有时是它的前一个元素)的链接,假设有一个链表,那么我们需要找到第二小的元素。以下是以下场景。

让我们假设一些简单的输入和输出场景

假设这个场景,我们有一个链表,其中包含的元素是“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

相关文章

JavaScript2024新功能:Object.groupBy、正则表达式v标志
PHP trim 函数对多字节字符的使用和限制
新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
为React 19做准备:WordPress 6.6用户指南
如何删除WordPress中的所有评论

发布评论