当前位置: 首页>>代码示例>>C#>>正文


C# Queue.Any方法代码示例

本文整理汇总了C#中Queue.Any方法的典型用法代码示例。如果您正苦于以下问题:C# Queue.Any方法的具体用法?C# Queue.Any怎么用?C# Queue.Any使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Queue的用法示例。


在下文中一共展示了Queue.Any方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: CommandLineParser

        public CommandLineParser(params string[] args)
        {
            var queue = new Queue<string>(args);

            Options = new Dictionary<string, string>();
            var errors = new List<string>();

            while (queue.Any())
            {
                var item = queue.Dequeue();

                if (!queue.Any() || IsKey(queue.Peek()))
                {
                    errors.Add(string.Format("Option {0} is missing its required value.", item));
                    break;
                }

                var key = KeyName(item);
                var value = queue.Dequeue();

                Options.Add(key, value);
            }

            Errors = errors.ToArray();
        }
开发者ID:scichelli,项目名称:Nautilus-Build,代码行数:25,代码来源:CommandLineParser.cs

示例2: MadeRows

        private static void MadeRows(string[] words)
        {
            Queue<string> queue = new Queue<string>();
            for (int i = 0; i < words.Length; i++)
            {
                queue.Enqueue(words[i]);
            }
            int currentRowLength = 0;
            int wordsCount = 0;
            string currentWord = String.Empty;
            List<string> current = new List<string>();
            int counter = 0;

            while (true)
            {

                if (!queue.Any())
                {
                    break;
                }
                currentWord = queue.Peek();
                currentRowLength += currentWord.Length + 1;
                wordsCount++;
                if (currentRowLength <= lineWidth + 1)
                {
                    current.Add(queue.Dequeue());
                    counter++;
                }
                if (currentRowLength > lineWidth + 1 || !queue.Any())
                {
                    int spaces = lineWidth - String.Join("", current).Trim().Length;
                    int i = 0;
                    while (spaces > 0)
                    {
                        if (current.Count > 1)
                        {
                            if (i == current.Count - 1)
                            {
                                i = 0;
                            }
                            if (i < current.Count - 1)
                            {
                                current[i] = current[i] + " ";
                                spaces--;
                            }
                            i++;
                        }
                        else
                        {
                            break;
                        }
                    }
                    Console.WriteLine(String.Join("", current).Trim());
                    current.Clear();
                    currentRowLength = 0;
                }
            }
        }
开发者ID:VDGone,项目名称:TelerikAcademy-1,代码行数:58,代码来源:ConsoleJustification.cs

示例3: GetEventsWhile

 private static IEnumerable<GherkinEvent> GetEventsWhile(Queue<GherkinEvent> events, Predicate<GherkinEvent> continueIfEventIsNot)
 {
     if (events.Any() == false)
         yield break;
     GherkinEvent nextEvent;
     do
     {
         yield return events.Dequeue();
         nextEvent = (events.Any()) ? events.Peek() : null;
     } while (events.Any() && !(continueIfEventIsNot(nextEvent)));
 }
开发者ID:AngelPortal,项目名称:NBehave,代码行数:11,代码来源:GroupEventsByFeature.cs

示例4: AsyncExecute

    public async Task AsyncExecute(Item[] items, int runnerCount) {
      var queue = new Queue<Item>(items);
      var tasks = new List<Task<Item>>();

      while (tasks.Any() || queue.Any()) {
        while (tasks.Count() != runnerCount && queue.Any())
          tasks.Add(CompressUsingZipFile(queue.Dequeue()));
        var task = await Task.WhenAny(tasks);
        tasks.Remove(task);
        await task;
      }
    }
开发者ID:asipe,项目名称:area51,代码行数:12,代码来源:TaskFileZip.cs

示例5: GeraGrade

        private Matricula GeraGrade()
        {
            var grade = new Matricula(_restricoes);

            var fila = new Queue<Disciplina>();
            var continua = true;

            foreach (var disciplina in ranking.Keys.ToList())
            {
                fila.Enqueue(disciplina);
            }

            do
            {
                if (fila.Any())
                {
                    grade.AdicionarDisciplina(fila.Dequeue());
                }
                else
                {
                    continua = false;
                }
            } while (continua);

            return grade;
        }
开发者ID:lucasmedi,项目名称:AconselhadorDeMatricula,代码行数:26,代码来源:Aconselhador.cs

示例6: GetSupportedChildProjects

        /// <summary>
        /// Recursively retrieves all supported child projects of a virtual folder.
        /// </summary>
        /// <param name="project">The root container project</param>
        public static IEnumerable<Project> GetSupportedChildProjects(this Project project)
        {
            if (!project.IsSolutionFolder())
            {
                yield return project;
            }

            var containerProjects = new Queue<Project>();
            containerProjects.Enqueue(project);

            while (containerProjects.Any())
            {
                var containerProject = containerProjects.Dequeue();
                foreach (ProjectItem item in containerProject.ProjectItems)
                {
                    var nestedProject = item.SubProject;
                    if (nestedProject == null)
                    {
                        continue;
                    }
                    else if (nestedProject.IsSupported())
                    {
                        yield return nestedProject;
                    }
                    else if (nestedProject.IsSolutionFolder())
                    {
                        containerProjects.Enqueue(nestedProject);
                    }
                }
            }
        }
开发者ID:OpenRIAServices,项目名称:OpenRiaServices,代码行数:35,代码来源:ProjectExtensions.cs

示例7: EnumerateTargets

        public IEnumerable<Tuple<Vector, Stack<RobotMove>>> EnumerateTargets(Func<Map, Vector, HashSet<Vector>, int, bool> isTarget)
        {
            var q = new Queue<WaveCell>();
            q.Enqueue(new WaveCell(startPosition, 0, null, RobotMove.Wait, map.WaterproofLeft, map.Razors));
            var used = new HashSet<Vector>();
            used.Add(startPosition);
            int stepsDone = 0;
            while (q.Any() && stepsDone < maxStepsCount)
            {
                stepsDone++;
                var cell = q.Dequeue();
                MapCell toCell = map.GetCell(cell.Pos);
                if (!cell.Pos.Equals(startPosition)
                    && (isTarget(map, cell.Pos, used, cell.StepNumber)))
                    yield return CreateTarget(cell);
                if (toCell == MapCell.OpenedLift || toCell == MapCell.ClosedLift)
                    Lift = CreateTarget(cell);
                foreach (var move in map.IsInWater(cell.StepNumber, cell.Pos.Y) ? RobotMovesInWater : RobotMoves)
                {
                    Vector newPos = cell.Pos.Add(move.ToVector());
                    if (!map.IsValidMoveWithoutMovingRocks(cell.Pos, newPos)) continue;

                    newPos = map.GetTrampolineTarget(newPos);
                    var mapcell = map.GetCell(newPos);

                    if ((!used.Contains(newPos) && (map.GetCell(newPos) == MapCell.OpenedLift || map.IsSafeMove(cell.Pos, newPos, cell.StepNumber + 1, cell.WaterproofLeft)))
                        && (mapcell != MapCell.Beard || cell.RazorsLeft > 0))
                    {
                        var wp = map.IsInWater(cell.StepNumber, newPos.Y) ? cell.WaterproofLeft - 1 : map.Waterproof;
                        q.Enqueue(new WaveCell(newPos, cell.StepNumber + 1, cell, move, wp, mapcell == MapCell.Beard ? map.Razors - 1: map.Razors));
                        used.Add(newPos);
                    }
                }
            }
        }
开发者ID:xoposhiy,项目名称:icfpc2012,代码行数:35,代码来源:WaveRun.cs

示例8: V

        public static string V(ICode c) {
            var method = c.Ctx.MRef;
            StringBuilder sb = new StringBuilder();
            sb.Append(method.FullName);
            var seen = new HashSet<ICode>() { c };
            var todo = new Queue<Stmt>();
            todo.Enqueue((Stmt)c);
            while (todo.Any()) {
                var cBlock = todo.Dequeue();
                var v = new ShowVisitor();
                v.Visit(cBlock);
                sb.AppendLine();
                sb.Append(GetStmtName(cBlock) + ":");
                sb.Append(v.Code);
                foreach (var continuation in v.Continuations) {
                    if (seen.Add(continuation.To)) {
                        todo.Enqueue(continuation.To);
                    }
                }
            }

            sb.AppendLine();
            sb.Append("}");
            return sb.ToString();
        }
开发者ID:chrisdunelm,项目名称:DotNetWebToolkit,代码行数:25,代码来源:ShowVisitor.cs

示例9: AllPositions

 public IList<Tuple<Unit, IList<MoveType>>> AllPositions(Unit currentUnit)
 {
     if (!currentUnit.IsCorrect(map))
     {
         return new Tuple<Unit, IList<MoveType>>[0];
     }
     var checker = new ForbiddenSequenceChecker(currentUnit);
     var visited = new Dictionary<Unit, List<MoveType>>
     {
         { currentUnit, new List<MoveType>() },
     };
     var queue = new Queue<Unit>(new[] { currentUnit });
     while (queue.Any())
     {
         var unit = queue.Dequeue();
         foreach (var move in allowedMoves.Where(m => checker.CheckLastMove(visited[unit], m)))
         {
             var next = unit.Move(move);
             if (!next.IsCorrect(map) || visited.ContainsKey(next))
                 continue;
             queue.Enqueue(next);
             visited[next] = visited[unit].Concat(new[] { move }).ToList();
         }
     }
     return visited.Keys.Select(u => Tuple.Create(u, (IList<MoveType>)visited[u])).ToList();
 }
开发者ID:spaceorc,项目名称:icfpc2015,代码行数:26,代码来源:ReachablePositions.cs

示例10: ForNodes

        public static void ForNodes(this Dictionary<IToken, List<INode>> nodeDependencies, TreeContext context, Action<INode> action)
        {
            var nodesQueue = new Queue<INode>(new[] { context.Tree.Root });
            var assigned = new HashSet<IToken> { context.Tree.Root.Token };
            while (nodesQueue.Any())
            {
                var current = nodesQueue.Dequeue();
                List<INode> children;
                if (!nodeDependencies.TryGetValue(current.Token, out children))
                {
                    continue;
                }

                foreach (var child in children)
                {
                    var dependencies = context.GetDependencies(child);
                    if (!dependencies.All(x => assigned.Contains(x.Token)))
                    {
                        continue;
                    }

                    action(child);
                    assigned.Add(child.Token);
                    nodesQueue.Enqueue(child);
                }
            }
        }
开发者ID:repinvv,项目名称:TestingContext,代码行数:27,代码来源:NodeDependencyIteration.cs

示例11: ConstructHypergraph

        //
        // On-Demand hypergraph construction.
        //
        public Hypergraph.Hypergraph<Region, SimpleRegionEquation> ConstructHypergraph()
        {
            Queue<Region> worklist = new Queue<Region>();
            List<ShapeRegion> shapeRegions = new List<ShapeRegion>();

            // Add all the shapes to the worklist.
            foreach(Figure fig in figures)
            {
                ShapeRegion r = new ShapeRegion(fig);

                shapeRegions.Add(r);

                worklist.Enqueue(r);
            }

            //
            // Deconstruct non-atomic regions, construct atomic regions.
            //
            while(worklist.Any())
            {
                Region currRegion = worklist.Dequeue();

                if (!currRegion.IsAtomic()) RegionDecomposition(currRegion, shapeRegions, worklist);

                if (currRegion.IsAtomic()) RegionComposition(currRegion, shapeRegions, worklist);
            }

            graph.DebugDumpClauses();

            Debug.WriteLine(graph.ToString());

            return graph;
        }
开发者ID:wcatykid,项目名称:GeoShader,代码行数:36,代码来源:SynthesisAreaHypergraphCreator.cs

示例12: TraverseTheMatrix

        public static int[,] TraverseTheMatrix(int[,] matrix, Cell startingCell)
        {
            var queue = new Queue<Cell>();
            queue.Enqueue(startingCell);

            while (queue.Any())
            {
                var cell = queue.Dequeue();
                matrix[cell.X, cell.Y] = cell.Value;

                for (int index = 0; index < Direction.Length; index += 2)
                {
                    if (IsNextCellUsable(matrix,cell,index))
                    {
                        queue.Enqueue(new Cell
                            (
                            cell.X + Direction[index],
                            cell.Y + Direction[index + 1],
                            cell.Value + 1
                            ));
                    }
                }
            }
            return matrix;
        }
开发者ID:dhristoskov,项目名称:DateStructure,代码行数:25,代码来源:HorseRideTravers.cs

示例13: FillFrom

        public void FillFrom(Point currentPoint, byte label, byte[] imageData, Size imageSize, byte[] labelData)
        {
            var nextPointsQueue = new Queue<Point>();
            nextPointsQueue.Enqueue(currentPoint);

            while (nextPointsQueue.Any())
            {
                currentPoint = nextPointsQueue.Dequeue();

                var currentLabel = _GetPixel(currentPoint, labelData, imageSize);
                if (currentLabel != 0) { continue; }

                _SetPixel(currentPoint, label, labelData, imageSize);

                var currentValue = _GetPixel(currentPoint, imageData, imageSize);

                var sameValueNeighborPoints =
                    _testPoints
                        .Select(tp => new Point(currentPoint.X + tp.X, currentPoint.Y + tp.Y))
                        .Where(p => _GetPixel(p, imageData, imageSize) != null) // Izbaci susjede van slike
                        .Where(p => _GetPixel(p, imageData, imageSize) == currentValue) // Izbaci elemente koji nisu iste boje kao trenutni
                        .Where(p => _GetPixel(p, labelData, imageSize) == 0) // Izbaci elemente koji vec imaju labelu
                        .ToList();

                sameValueNeighborPoints.ForEach(nextPointsQueue.Enqueue);
            }
        }
开发者ID:IvanMacek,项目名称:connectedcomponents,代码行数:27,代码来源:FloodFillAlgorithm.cs

示例14: Process

        void Process(Node targetNode, Queue<Token> tokenQueue, TreeBuilderState state)
        {
            state.ProcessingState = new ProcessingState(targetNode, tokenQueue);

            while (tokenQueue.Any())
            {
                var token = tokenQueue.Dequeue();
                var tokenType = token.Type;

                var rule = rules
                    .Where(r => r.TokenType == tokenType)
                    .FirstOrDefault();

                if (rule == null)
                {
                    targetNode.AddChild(new ParseFailureNode(token, "unexpected token"));
                    break;
                }

                var node = rule.NodeBuilder(token, state);

                if (node != null)
                    targetNode.AddChild(node);
            }
        }
开发者ID:tathamoddie,项目名称:RegexAnalyzer,代码行数:25,代码来源:TreeBuilder.cs

示例15: Transitize

            public void Transitize()
            {
                Queue<Flow> q = new Queue<Flow>(_flows.Values);

                // DEBUG only
                // var copy = new List<KeyValuePair<SignalBase, Flow>>(_flows);

                while (q.Any())
                {
                    var flow = q.Dequeue();
                    SignalFlow sflow = flow as SignalFlow;
                    if (sflow != null)
                    {
                        Flow trflow;
                        if (_flows.TryGetValue(sflow.Source, out trflow))
                        {
                            SignalFlow strflow = trflow as SignalFlow;
                            if (strflow != null)
                            {
                                trflow = new SignalFlow(strflow.Source, sflow.Target);
                            }
                            ValueFlow vtrflow = trflow as ValueFlow;
                            if (vtrflow != null)
                            {
                                trflow = new ValueFlow(vtrflow.Value, sflow.Target);
                            }
                            _flows[sflow.Target] = trflow;
                            if (trflow.Equals(sflow))
                                throw new InvalidOperationException("Cyclic dataflow");

                            q.Enqueue(trflow);
                        }
                    }
                }
            }
开发者ID:venusdharan,项目名称:systemsharp,代码行数:35,代码来源:FlowMatrix.cs


注:本文中的Queue.Any方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。