本文整理汇总了C#中PriorityQueue.Insert方法的典型用法代码示例。如果您正苦于以下问题:C# PriorityQueue.Insert方法的具体用法?C# PriorityQueue.Insert怎么用?C# PriorityQueue.Insert使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类PriorityQueue
的用法示例。
在下文中一共展示了PriorityQueue.Insert方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: PriorityQueueSimpleTest
public void PriorityQueueSimpleTest()
{
PriorityQueue<int> pQueue = new PriorityQueue<int>(10);
pQueue.Insert(4);
pQueue.Insert(6);
pQueue.Insert(3);
pQueue.Insert(8);
Assert.AreEqual(3, pQueue.DeleteMin());
}
示例2: PriorityQueueDoubleDeleteTest
public void PriorityQueueDoubleDeleteTest()
{
PriorityQueue<int> pQueue = new PriorityQueue<int>(10);
pQueue.Insert(4);
pQueue.Insert(1);
pQueue.Insert(3);
pQueue.Insert(8);
pQueue.Insert(0);
Assert.AreEqual(0, pQueue.DeleteMin());
Assert.AreEqual(1, pQueue.DeleteMin());
}
示例3: Compute
/// <summary>
/// The dijkstra's shortest path procedure for a directed " non-negative " weighted graphs.
/// </summary>
/// <param name="directedGraph">
/// a directed graph containing a set V of n vertices
/// and a set E of m directed edges with nonnegative weights.
/// </param>
/// <param name="sourceVertex">a source vertex in V.</param>
/// <remarks>
/// Result:
/// For each non-source vertex v in V, shortest[v] is the weight sp(s,v) of a shortest path from s to v and pred(v) is the vertex
/// preceding v on some shortest path.
/// For the source vertex s, shortest(s) = 0 and pred(s) = NULL.
/// If there is no path from s to v, then shortest[v] = infinity, and pred(v) = NULL.
/// </remarks>
public void Compute(IGraph directedGraph, int sourceVertex)
{
Graph.Shortest = new double[directedGraph.N];
Graph.Predecessors = new int?[directedGraph.N];
for (int i = 0; i < directedGraph.N; ++i)
{
Graph.Shortest[i] = double.PositiveInfinity;
Graph.Predecessors[i] = null;
}
Graph.Shortest[sourceVertex] = 0;
var queue = new PriorityQueue<int>();
foreach (var v in directedGraph.Vertices)
queue.Insert(v);
while (queue.Count > 0)
{
var u = queue.ExtractMin();
double tempShortest;
foreach (var v in directedGraph[u])
{
tempShortest = Shortest[v];
Graph.Relax(directedGraph, u, v);
if (tempShortest != Shortest[v])
queue.DecreaseKey(v);
}
}
}
示例4: TestPriorityQueue
public static void TestPriorityQueue()
{
Random r = new Random();
int size = 7;
int range = 100;
PriorityQueue q = new PriorityQueue(size);
Console.WriteLine("-----Test INSERT-----");
for (int i = 0; i < size; i++)
{
double val = r.NextDouble() * range;
if (!q.Insert(i, val))
{
Console.WriteLine("ERROR on index " + i + " with value " + val.ToString("#.##"));
return;
}
Console.WriteLine("inserted item " + i + " with value " + val.ToString("#.##"));
Console.WriteLine("queue:\n" + q.ToString());
}
Console.WriteLine();
Console.WriteLine("-----Test REDUCE_VAL-----");
for (int i = 0; i < size; i++)
{
double val = r.NextDouble() * range;
if (q.ReduceVal(i, val))
{
Console.WriteLine("update item " + i + " with value " + val.ToString("#.##"));
Console.WriteLine("queue:\n" + q.ToString());
}
else {
Console.WriteLine("ERROR updating index " + i + " with value " + val.ToString("#.##"));
}
}
Console.WriteLine();
Console.WriteLine("-----Test GET_VAL-----");
for (int i = 0; i < size; i++)
{
Console.WriteLine("Node " + i + " has a value of " + q.GetVal(i).ToString("#.##"));
}
Console.WriteLine();
Console.WriteLine("-----Test POP_MIN-----");
for (int i = 0; i < size; i++)
{
int id = q.PopMin();
Console.WriteLine("popped " + id + " off the queue");
Console.WriteLine("queue:\n" + q.ToString());
}
Console.WriteLine("ALL DONE");
}
示例5: TryTakeTopItemTest
public void TryTakeTopItemTest()
{
var queue = new PriorityQueue<int>();
queue.Insert(1);
int topItem;
Assert.IsTrue(queue.TryTakeTopItem(out topItem));
Assert.AreEqual(topItem, 1);
Assert.IsFalse(queue.TryTakeTopItem(out topItem));
}
示例6: Run
public static void Run(Vertex vertex)
{
vertex.Depth = 0;
PriorityQueue<Vertex> queue = new PriorityQueue<Vertex>((x, y) => y.Depth.CompareTo(x.Depth));
queue.Insert(vertex);
while(!queue.IsEmpty)
{
Vertex current = queue.Pop();
foreach(Edge edge in current.Edges)
{
if(edge.From.Depth + edge.Weight < edge.To.Depth)
{
edge.To.Depth = edge.From.Depth + edge.Weight;
edge.To.Parent = edge.From;
queue.Insert(edge.To);
}
}
}
}
示例7: InsertTest
public void InsertTest()
{
var range = new int[ARRAY_SIZE];
var random = new Random();
var queue = new PriorityQueue<int>();
for (int i = 0; i < ARRAY_SIZE; i++)
{
var number = random.Next(int.MaxValue);
range[i] = number;
queue.Insert(number);
}
TestSort(range, queue);
}
示例8: AllPathDijkstra
public double AllPathDijkstra(Stopwatch s)
{
int n_nodes = points.Count();
PriorityQueue q = new PriorityQueue(n_nodes);
double[] src_dist = new double[n_nodes];
int[] prev = new int[n_nodes];
int i;
s.Start();
for (i = 0; i < n_nodes; i++)
{
src_dist[i] = double.MaxValue;
prev[i] = -1;
q.Insert(i, src_dist[i]);
}
src_dist[src] = 0;
q.ReduceVal(src, src_dist[src]);
while (!q.IsEmpty())
{
int id = q.PopMin();
HashSet<int> adj_nodes = adjacencyList[id];
for (i = 0; i < adj_nodes.Count(); i++)
{
int temp_id = adj_nodes.ElementAt(i);
double temp_dist = src_dist[id] + GetDist(points[id], points[temp_id]);
//Console.WriteLine("Distance from " + id + " to " + temp_id + " is " + temp_dist);
if (temp_dist < src_dist[temp_id]) // If the node HAS been visited and the temp distance is less than the previous distance
{
src_dist[temp_id] = temp_dist;
prev[temp_id] = id;
if (!q.ReduceVal(temp_id, temp_dist))
{
Console.WriteLine("ERROR reducing id " + temp_id + " connected to id " + id);
return 1;
}
//Console.WriteLine("queue:\n" + q.ToString());
}
}
}
s.Stop();
return src_dist[dst];
}
示例9: Main
static void Main()
{
var test = new PriorityQueue<int>();
test.Insert(1);
test.Insert(2);
test.Insert(3);
test.Insert(4);
test.Insert(0);
test.Insert(20);
test.Insert(7);
test.Insert(3000);
var count = test.Size;
for (int i = 0; i < count; i++)
{
Console.WriteLine(test.Pop());
}
}
示例10: Main
static void Main(string[] args)
{
PriorityQueue<int> pq = new PriorityQueue<int>();
for (int i = 0; i < 13; i++)
{
pq.Insert(i);
}
foreach (var item in pq)
{
Console.WriteLine(item);
}
Console.WriteLine("*********************");
//while (!pq.IsEmpty)
//{
// Console.WriteLine(pq.RemoveMin());
//}
Console.ReadLine();
}
示例11: Main
static void Main()
{
//var testHeap = new BinaryHeap<int>();
//testHeap.Add(5);
//testHeap.Add(6);
//testHeap.Add(7);
//testHeap.Add(8);
//testHeap.Add(9);
//testHeap.Add(1);
//testHeap.Add(2);
//testHeap.Add(3);
//testHeap.Add(31);
//testHeap.Add(4);
var testPriorityQueue = new PriorityQueue<string>();
testPriorityQueue.Insert("Pesho", 1);
testPriorityQueue.Insert("Gosho", 3);
testPriorityQueue.Insert("Ganka", 2);
testPriorityQueue.Insert("Tyanko", 7);
testPriorityQueue.Insert("Minka", 5);
testPriorityQueue.Insert("Zhelyo", 6);
}
示例12: OnePathDijkstra
public double OnePathDijkstra(Stopwatch s)
{
int n_nodes = points.Count();
PriorityQueue q = new PriorityQueue(n_nodes);
double[] src_dist = new double[n_nodes];
int[] prev = new int[n_nodes];
int i;
s.Start();
for (i = 0; i < n_nodes; i++)
{
src_dist[i] = double.MaxValue;
prev[i] = -1;
}
src_dist[src] = 0;
prev[src] = -1;
q.Insert(src, src_dist[src]);
while (!q.IsEmpty())
{
int id = q.PopMin();
if (id == dst) { break; }
HashSet<int> adj_nodes = adjacencyList[id];
for (i = 0; i < adj_nodes.Count(); i++)
{
int temp_id = adj_nodes.ElementAt(i);
double temp_dist = src_dist[id] + GetDist(points[id], points[temp_id]);
if (src_dist[temp_id] == double.MaxValue) // If the node has NOT been visited
{
src_dist[temp_id] = temp_dist;
prev[temp_id] = id;
if (!q.Insert(temp_id, src_dist[temp_id]))
{
Console.WriteLine("ERROR inserting id " + temp_id + " connected to id " + id);
return 1;
}
}
else if (temp_dist < src_dist[temp_id]) // If the node HAS been visited and the temp distance is less than the previous distance
{
src_dist[temp_id] = temp_dist;
prev[temp_id] = id;
if (!q.ReduceVal(temp_id, temp_dist))
{
Console.WriteLine("ERROR reducing id " + temp_id + " connected to id " + id);
return 1;
}
}
}
}
s.Stop();
if (src_dist[dst] != double.MaxValue)
{
Pen pen = new Pen(Color.Black);
Font font = new Font("Arial", 8);
SolidBrush brush = new SolidBrush(Color.Black);
int temp = dst;
while (prev[temp] != -1)
{
PointF p1 = points[temp];
PointF p2 = points[prev[temp]];
graphics.DrawLine(pen, p1, p2);
graphics.DrawString(GetDist(p1, p2).ToString("#.##"), font, brush, GetMidPoint(p1, p2));
temp = prev[temp];
}
pictureBox.Refresh();
}
else
{
Console.WriteLine("Destination is unreachable");
}
return src_dist[dst];
}
示例13: FindPath
public bool FindPath()
{
//Check if indexes are valid
if (!IsIndexValid (First) || !IsIndexValid (Last))
return false;
//Check if starting and ending position are same
if (First == Last) {
ConstructPath (new Dictionary<Point, Point> (), Last);
return true;
}
var profiler = new Stopwatch ();
profiler.Start ();
//Create open/close sets and cameFrom
var closed = new HashSet<Point> ();
var open = new PriorityQueue<Point> (true);
var cameFrom = new Dictionary<Point, Point> ();
//Create f/g score dicts
var gScore = new Dictionary<Point, float> ();
var fScore = new Dictionary<Point, float> ();
//Prepare the first node
var current = First;
gScore [current] = 0f;
fScore [current] = gScore [current] + CostEstimate (current, Last);
open.Insert (current, fScore [current]);
//Main loop
while (!open.IsEmpty) {
//Take the first in the priority queue
current = open.Pop ();
closed.Add (current);
//If goal reached
if (current == Last) {
ConstructPath (cameFrom, current);
profiler.Stop ();
ComputationTime = profiler.Elapsed;
return true;
}
//Iterate neighbours
var neighbours = GetNeighbours (current);
foreach (var neighbourPair in neighbours) {
var neighbour = neighbourPair.Key;
var cost = neighbourPair.Value;
//Don't search closed nodes
if (closed.Contains (neighbour))
continue;
//Check if it's worth it
var tentativeGScore = gScore [current] + cost;
if (open.Contains (neighbour) && tentativeGScore >= gScore [neighbour])
continue;
//Set up neighbour
cameFrom [neighbour] = current;
gScore [neighbour] = tentativeGScore;
fScore [neighbour] = gScore [neighbour] + CostEstimate (neighbour, Last);
//Change priority or add it to the priority queue
if (open.ChangePriority (neighbour, fScore [neighbour]))
continue;
open.Insert (neighbour, fScore [neighbour]);
}
}
profiler.Stop ();
ComputationTime = profiler.Elapsed;
return false;
}
示例14: DoSearch
private void DoSearch(ulong q, int τ, PriorityQueue W, List<Node> node)
{
if (!node.Any()) return;
// Leaf node : test each element in this node's bucket.
if (node.Count > 1)
{
var n = node.Count;
for (var i = 0; i < n; i++)
{
comparisons++;
var elementID = node[i].i;
var element = S[elementID];
var elementDist = distance(q, element);
if (elementDist < τ)
{
τ = W.Insert(elementID, elementDist) ?? τ;
}
}
return;
}
// Non-leaf node
var id = node[0].i;
var p = S[id];
var dist = distance(q, p);
comparisons++;
// This vantage-point is close enough to q.
if (dist < τ)
{
τ = W.Insert(id, dist) ?? τ;
}
// The order of exploration is determined by comparison with μ.
// The sooner we find elements close to q, the smaller τ and the more nodes we skip.
// P. Yianilos uses the middle of left/right bounds instead of μ.
var μ = node[0].μ;
var L = node[0].L;
var R = node[0].R;
//if (μ == null)
// return;
if (dist < μ)
{
if (L.Any() && node[0].m - τ < dist)
{
DoSearch(q, τ, W, L);
}
if (R.Any() && μ - τ < dist && dist < node[0].M + τ)
{
DoSearch(q, τ, W, R);
}
}
else
{
if (R.Any() && dist < node[0].M + τ)
{
DoSearch(q, τ, W, R);
}
if (L.Any() && node[0].m - τ < dist && dist < μ + τ)
{
DoSearch(q, τ, W, L);
}
}
}
示例15: PriorityQueueDuplicateElementsTest
public void PriorityQueueDuplicateElementsTest()
{
var values = new[] { 3, 3, 3, 5, 3, 3, 3, 3 };
var maxpq = new PriorityQueue<int>(ExtremeType.Maximum);
Assert.IsTrue(maxpq.IsEmpty);
for (int i = 0; i < values.Length; i++)
{
maxpq.Insert(values[i]);
}
Assert.AreEqual(5, maxpq.DeleteExtreme());
while (!maxpq.IsEmpty)
{
int curr = maxpq.DeleteExtreme();
Assert.AreEqual(3, curr);
}
}