在 C++ 中查找单向循环链表的最小元素和最大元素
这里我们将演示如何从一个单向循环链表中获取最小值和最大值。基本概念非常简单。最后一个节点的下一部分将指向第一个节点,第一个节点也将使用开始指针指向。当我们向链表中插入某个元素时,在插入之后,新插入的节点下一部分将使用开始节点的地址进行更新。
最初,min 被赋予正无穷大,max 被赋予负无穷大。现在从左至右遍历链表。如果当前元素小于 min 元素,则更新 min,如果当前元素大于 max 元素,则更新 max。因此,我们可以得到 min 和 max 值。
示例
#include<iostream>
using namespace std;
class Node{
public:
int data;
Node *next;
};
Node* getNode(int key){
Node *newNode = new Node();
newNode->data = key;
newNode->next = NULL;
return newNode;
}
void insert(Node **start, int data){
Node *current = *start;
Node *newNode = getNode(data);
if(*start == NULL){
newNode->next = newNode;
*start = newNode;
return;
}
while (current->next != *start) {
current = current->next;
}
newNode->next = *start;
current->next = newNode;
}
void displayList(Node *start){
Node* current = start;
if (start == NULL) {
cout << "Display List is empty";
return;
} else {
do {
cout << current->data << " ";
current = current->next;
}
while (current != start);
}
cout << endl;
}
void getMinMax(Node **start){
if(*start == NULL){
return;
}
Node* current;
current = *start;
int min = INT_MAX, max = INT_MIN;
while (current->next != *start) {
if (current->data < min) {
min = current->data;
}
if (current->data > max) {
max = current->data;
}
current = current->next;
}
cout << "Minimum: " << min << ", Maximum: " << max;
}
int main() {
int data[] = {99, 11, 22, 10, 44, 55, 66};
int n = sizeof(data)/sizeof(data[0]);
Node *start = NULL;
for(int i = 0; i<n; i++){
insert(&start, data[i]);
}
displayList(start);
getMinMax(&start);
}输出
99 11 22 10 44 55 66 Minimum: 10, Maximum: 99
广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP