堆栈表示对象的后进先出集合。当您需要对项目进行后进先出的访问时,可以使用它。在列表中添加项目时,称为推送项目,而在删除项目时,则称为弹出项目。 Stack
特性:
- 堆栈的容量是堆栈可以容纳的元素数量。将元素添加到堆栈后,容量会根据需要通过重新分配自动增加。
- 如果Count小于堆栈的容量,则Push是O(1)运算。如果需要增加容量以容纳新元素,则Push变为O(n)操作,其中n为Count。 Pop是O(1)运算。
- 堆栈接受null作为有效值,并允许重复的元素。
句法:
public T[] ToArray ();
返回类型:此方法返回一个新的数组t [] ,该数组包含Stack
下面给出了一些示例,以更好地理解实现:
范例1:
// C# code to Convert Stack to array
using System;
using System.Collections.Generic;
class GFG {
// Driver code
public static void Main()
{
// Creating a Stack of strings
Stack myStack = new Stack();
// Inserting the elements into the Stack
myStack.Push("Geeks");
myStack.Push("Geeks Classes");
myStack.Push("Noida");
myStack.Push("Data Structures");
myStack.Push("GeeksforGeeks");
// Converting the Stack into array
String[] arr = myStack.ToArray();
// Displaying the elements in array
foreach(string str in arr)
{
Console.WriteLine(str);
}
}
}
输出:
GeeksforGeeks
Data Structures
Noida
Geeks Classes
Geeks
范例2:
// C# code to Convert Stack to array
using System;
using System.Collections.Generic;
class GFG {
// Driver code
public static void Main()
{
// Creating a Stack of Integers
Stack myStack = new Stack();
// Inserting the elements into the Stack
myStack.Push(2);
myStack.Push(3);
myStack.Push(4);
myStack.Push(5);
myStack.Push(6);
// Converting the Stack into array
int[] arr = myStack.ToArray();
// Displaying the elements in array
foreach(int i in arr)
{
Console.WriteLine(i);
}
}
}
输出:
6
5
4
3
2
参考:
- https://docs.microsoft.com/zh-cn/dotnet/api/system.collections.generic.stack-1.toarray?view=netframework-4.7.2