本文整理汇总了C#中Queue.Contains方法的典型用法代码示例。如果您正苦于以下问题:C# Queue.Contains方法的具体用法?C# Queue.Contains怎么用?C# Queue.Contains使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Queue
的用法示例。
在下文中一共展示了Queue.Contains方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: PosTest1
public bool PosTest1()
{
bool retVal = true;
TestLibrary.TestFramework.BeginScenario("PosTest1: Test whether Contains() is successful.");
try
{
Queue<string> TestQueue = new Queue<string>();
TestQueue.Enqueue("one");
TestQueue.Enqueue("two");
if (!TestQueue.Contains("one") || !TestQueue.Contains("two") || TestQueue.Contains("three"))
{
TestLibrary.TestFramework.LogError("P01.1", "Contains() failed!");
retVal = false;
}
}
catch (Exception e)
{
TestLibrary.TestFramework.LogError("P01.2", "Unexpected exception: " + e);
TestLibrary.TestFramework.LogVerbose(e.StackTrace);
retVal = false;
}
return retVal;
}
示例2: ContainsUsesEqualsMethod
public void ContainsUsesEqualsMethod() {
var q = new Queue<C>();
q.Enqueue(new C(1));
q.Enqueue(new C(2));
q.Enqueue(new C(3));
Assert.IsTrue(q.Contains(new C(2)));
Assert.IsFalse(q.Contains(new C(4)));
}
示例3: ContainsWorks
public void ContainsWorks() {
var q = new Queue<int>();
q.Enqueue(10);
q.Enqueue(2);
q.Enqueue(4);
Assert.IsTrue(q.Contains(10));
Assert.IsTrue(q.Contains(2));
Assert.IsFalse(q.Contains(11));
}
示例4: TestContains
public void TestContains()
{
var q = new Queue<int>();
q.Enqueue(0);
Assert.AreEqual(1, q.Count);
Assert.IsTrue(q.Contains(0));
Assert.IsFalse(q.Contains(1));
}
示例5: operate
public int[] operate(int[] A, int[] B, string operation)
{
List<int> list = new List<int>();
List<int> list2 = new List<int>();
Queue<int> queue = new Queue<int>();
switch (operation)
{
case "UNION":
for (int i = 0; i < A.Length; i++)
list.Add(A[i]);
for (int i = 0; i < B.Length; i++)
{
if (!(list.Contains(B[i])))
list.Add(B[i]);
}
break;
case "INTERSECTION":
for (int i = 0; i < A.Length; i++)
queue.Enqueue(A[i]);
for (int i = 0; i < B.Length; i++)
queue.Enqueue(B[i]);
while (queue.Count > 0)
{
int temp = queue.Dequeue();
if (queue.Contains(temp) && !(list.Contains(temp)) && !(list2.Contains(temp)))
list.Add(temp);
else
list2.Add(temp);
}
break;
case "SYMMETRIC DIFFERENCE":
for (int i = 0; i < A.Length; i++)
queue.Enqueue(A[i]);
for (int i = 0; i < B.Length; i++)
queue.Enqueue(B[i]);
while (queue.Count > 0)
{
int temp = queue.Dequeue();
if (!queue.Contains(temp) && !(list.Contains(temp)) && !(list2.Contains(temp)))
list.Add(temp);
else
list2.Add(temp);
}
break;
}
int[] result = list.ToArray();
Array.Sort(result);
return result;
}
示例6: DisableThemeFeatures
public void DisableThemeFeatures(string themeName) {
var themes = new Queue<string>();
while (themeName != null) {
if (themes.Contains(themeName))
throw new InvalidOperationException(T("The theme \"{0}\" is already in the stack of themes that need features disabled.", themeName).Text);
var theme = _extensionManager.GetExtension(themeName);
if (theme == null)
break;
themes.Enqueue(themeName);
themeName = !string.IsNullOrWhiteSpace(theme.BaseTheme)
? theme.BaseTheme
: null;
}
var currentTheme = _siteThemeService.GetCurrentThemeName();
while (themes.Count > 0) {
var themeId = themes.Dequeue();
// Not disabling base theme if it's the current theme.
if (themeId != currentTheme) {
_featureManager.DisableFeatures(new[] { themeId });
}
}
}
示例7: FindShortestSequenceOfOperations
private static void FindShortestSequenceOfOperations(int n, int m, Queue<Func<int, int>> operations, Queue<int> sequence)
{
if (operations.Count < 1) { return; }
var ops = new Queue<Func<int, int>>(operations);
if (!sequence.Contains(n)) { sequence.Enqueue(n); }
int result = ops.Dequeue()(n);
if (result <= m) { sequence.Enqueue(result); }
if (result == m)
{
int depth = sequence.Count - 1;
while (sequence.Count > 0) { Console.Write(sequence.Dequeue() + " --> "); }
Console.Write(depth + " operations");
Console.WriteLine();
return;
}
if (result > m * 2) { return; }
if (result > m)
{
result = n;
}
FindShortestSequenceOfOperations(result, m, ops, sequence);
}
示例8: GetTiles
// Get a list of all the tiles that are connected using BFS
public List<Tile> GetTiles(Tile root)
{
List<Tile> tileList = new List<Tile>();
Queue<Tile> q = new Queue<Tile>();
q.Enqueue(root);
while (q.Count > 0)
{
// pop the first item in the queue
Tile current = q.Dequeue();
tileList.Add(current);
// if nothing pops, then all tiles have been found
if (current == null)
continue;
// loop through all of root's neighbouring tiles
foreach (Transform tile in current.Neighbours)
{
_color = root.GetComponent<Renderer>().material.color;
Color tileColor = tile.GetComponent<Renderer>().material.color;
// get the tile component from the transform
Tile t = tile.GetComponent<Tile>();
// if the two colours match, then the tile is a neighbour
// Enqueue the tile if it is not found in _tiles and in q
if (_color == tileColor && !(tileList.Contains(t)) && !(q.Contains(t)))
q.Enqueue(t);
}
}
return tileList;
}
示例9: Compressor
public Compressor(int bigDelta, int a, int eps, int dmax, Domain[,] domains, FractalCompression.Structure.Region[,] regions, List<MappedPoint> interpolationPoints, Bitmap bitmap)
{
this.bigDelta = bigDelta;
this.a = a;
this.smallDelta = bigDelta / a;
this.eps = eps;
this.dmax = dmax;
this.regions = regions;
this.domains = domains;
squeue = new Queue<FractalCompression.Structure.Region>();
foreach (FractalCompression.Structure.Region r in regions)
squeue.Enqueue(r);
iqueue = new Queue<MappedPoint>();
foreach (MappedPoint mp in interpolationPoints)
if (!iqueue.Contains(mp))
iqueue.Enqueue(mp);
aqueue = new Queue<int>();
cqueue = new Queue<double>();
squeue2 = new Queue<FractalCompression.Structure.Region>();
d = 1;
this.bitmap = bitmap;
this.h = new double[regions.Length, domains.Length];
this.minHQueue = new List<double>();
}
示例10: Main
static void Main(string[] args)
{
Queue<int> queue = new Queue<int>();
int[] commandArgs = Console.ReadLine().Split(' ').Select(int.Parse).ToArray();
int add = commandArgs[0];
int remove = commandArgs[1];
int find = commandArgs[2];
// Fill queue
int[] queueInput = Console.ReadLine().Split(' ').Select(int.Parse).ToArray();
for (int i = 0; i < add; i++)
{
queue.Enqueue(queueInput[i]);
}
// Remove Dequeue
for (int i = 0; i < remove; i++)
{
queue.Dequeue();
}
// Output
if (queue.Contains(find))
{
Console.WriteLine("true");
}
else
{
Console.WriteLine(queue.Count > 0 ? queue.Min() : 0);
}
}
示例11: Main
private static void Main(string[] args)
{
Console.Write("N=");
int n = int.Parse(Console.ReadLine());
Console.Write("M=");
int m = int.Parse(Console.ReadLine());
var members = new Queue<int>();
var visited = new HashSet<int>();
int operationsCount = 0;
long current = n;
members.Enqueue(n);
while (!members.Contains(m))
{
var tempQueue = new Queue<int>();
for (int i = members.Count-1; i >= 0; i--)
{
var item = members.Dequeue();
if (!visited.Contains(item) && item<m)
{
tempQueue.Enqueue(item + 1);
tempQueue.Enqueue(item + 2);
tempQueue.Enqueue(item * 2);
visited.Add(item);
}
}
operationsCount++;
members = tempQueue;
}
Console.WriteLine(operationsCount);
}
示例12: getTilesWithDistance
public static List<Tile> getTilesWithDistance(Tile originTile, int distance)
{
if (distance == 0)
return new List<Tile>();
HashSet<Tile> closedSet = new HashSet<Tile>();
Queue<Tile> openSet = new Queue<Tile>();
List<Tile> result = new List<Tile>();
foreach (Tile neighbour in originTile.Neighbours)
openSet.Enqueue(neighbour);
closedSet.Add(originTile);
while(openSet.Count > 0)
{
Tile tileToCheck = openSet.Dequeue();
var path = PathFinder.FindPath(originTile, tileToCheck);
closedSet.Add(tileToCheck);
if (path.ToList().Count - 1 <= distance)
{
result.Add(tileToCheck);
foreach (Tile tile in tileToCheck.Neighbours)
if (!closedSet.Contains(tile) && !openSet.Contains(tile))
openSet.Enqueue(tile);
}
}
return result;
}
示例13: CreateRandomState
public static EightPuzzleState CreateRandomState()
{
var result = new int[3, 3];
var randomizedNumbers = new Queue<int>(9);
for (int i = 0; i <= 8; i++)
{
int rnd;
do
{
rnd = _random.Next(0, 9);
}
while (randomizedNumbers.Contains(rnd));
randomizedNumbers.Enqueue(rnd);
}
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3; j++)
{
result[i, j] = randomizedNumbers.Dequeue();
}
}
return new EightPuzzleState(result);
}
示例14: Main
static void Main()
{
Queue<string> INPUT = new Queue<string>();
while (!INPUT.Contains("END"))
{
INPUT.Enqueue(Console.ReadLine().ToUpper());
}
BigInteger resultFirstTen = 1;
BigInteger resultOthers = 1;
int counter = 0; //first 10 elements or less
while(INPUT.Count > 1)
{
if (counter % 2 == 0)
{
foreach (char digit in INPUT.Dequeue().ToString())
{
resultFirstTen *= (digit - '0');
}
}
else
{
INPUT.Dequeue();
}
counter++;
if (counter==10) { break; }
}
while(INPUT.Count>1)
{
if (counter % 2 == 0)
{
foreach (char digit in INPUT.Dequeue().ToString())
{
resultOthers *= (digit - '0');
}
}
else
{
INPUT.Dequeue();
}
counter++;
}
if ( counter <=10)
{
Console.WriteLine(resultFirstTen.ToString());
}
else
{
Console.WriteLine(resultFirstTen.ToString());
Console.WriteLine(resultOthers.ToString());
}
}
示例15: Solve
private void Solve(TextReader reader)
{
while (true) {
var whs = reader.ReadLine().Split(' ').Select(s => int.Parse(s.Trim())).ToList();
var width = whs[0];
var height = whs[1];
if (width == 0 && height == 0) {
return;
}
var map = new List<string>();
for (int i = 0; i < height * 2 - 1; i++) {
var text = reader.ReadLine();
if (text.StartsWith(" ") && !text.EndsWith(" ")) {
text += " ";
}
map.Add(text);
}
var count = 0;
var que = new Queue<Tuple<int, int>>();
var newQue = new Queue<Tuple<int, int>>();
var walked = new HashSet<Tuple<int, int>>();
que.Enqueue(Tuple.Create(0, 0));
while (!que.Contains(Tuple.Create(2 * width - 2, 2 * height - 2)) && que.Count > 0) {
newQue.Clear();
while (que.Count > 0) {
var p = que.Dequeue();
var x = p.Item1;
var y = p.Item2;
foreach (var dxy in dxys) {
if (!walked.Contains(Tuple.Create(x + dxy.Item1 * 2,
y + dxy.Item2 * 2))) {
if (CanMove(map, x + dxy.Item1, y + dxy.Item2, x + dxy.Item1 * 2,
y + dxy.Item2 * 2)) {
newQue.Enqueue(Tuple.Create(x + dxy.Item1 * 2, y + dxy.Item2 * 2));
walked.Add(Tuple.Create(x + dxy.Item1 * 2, y + dxy.Item2 * 2));
}
}
}
}
var tmpQue = que;
que = newQue;
newQue = tmpQue;
count++;
}
if (que.Count == 0) {
Console.WriteLine(0);
} else {
Console.WriteLine(count + 1);
}
}
}