本文整理汇总了C#中Queue.Where方法的典型用法代码示例。如果您正苦于以下问题:C# Queue.Where方法的具体用法?C# Queue.Where怎么用?C# Queue.Where使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Queue
的用法示例。
在下文中一共展示了Queue.Where方法的13个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: InitializePrimes
private static int[] InitializePrimes(int limit)
{
var candidates = new Queue<int>(Enumerable.Range(2, limit - 1));
var primes = new List<int>();
do
{
var prime = candidates.Dequeue();
primes.Add(prime);
candidates = new Queue<int>(candidates.Where(x => x % prime != 0));
} while (candidates.Any());
return primes.ToArray();
}
示例2: UpdateMomentumMotion
private IEnumerator UpdateMomentumMotion()
{
Queue<TimedValue> speedQueue = new Queue<TimedValue> ();
while (true) {
moSpeed.isOnGround = Physics.Linecast(compTrans.position, compTrans.position + Vector3.down);
float speed = moSpeed.isOnGround ? engine.curSpeed : speedQueue.LastOrDefault().value;
speedQueue.Enqueue(new TimedValue() { value = speed, time = Time.time} );
if (speedQueue.Count > momentumParams.queueNums) {
speedQueue.Dequeue();
}
List<float> recentSpeeds = speedQueue
.Where(s => Time.time - s.time < momentumParams.queueTime)
.Select(s => s.value).ToList();
float avg = recentSpeeds.Aggregate(0f, (m, s) => m = m + s / recentSpeeds.Count);
moSpeed.speed = avg;
yield return null;
}
}
示例3: CalculateMFI
// Money Flow Index
public static void CalculateMFI(out string key, StockPoints data, Dictionary<DateTime, Dictionary<string, double>> indicators, int period, out int offset)
{
key = string.Format("MFI({0})", period.ToString("00"));
offset = period;
// Typical Price = (High + Low + Close)/3
double typicalPrice;
// Raw Money Flow = Typical Price x Volume
double rawMoneyFlow;
// Money Flow Ratio = (x-period Positive Money Flow)/(x-period Negative Money Flow)
double moneyFlowRatio;
// Money Flow Index = 100 - 100/(1 + Money Flow Ratio)
double moneyFlowIndex;
double positiveMoneyFlow = 0D;
double negativeMoneyFLow = 0D;
Queue<double> moneyFlow = new Queue<double>();
double previousTipycalPrice = (data[0].Low + data[0].High + data[0].Close) / 3;
int i = 0;
foreach (StockPoint point in data.Skip(1))
{
typicalPrice = (point.Low + point.High + point.Close) / 3;
rawMoneyFlow = typicalPrice * point.Volume;
moneyFlow.Enqueue(rawMoneyFlow * (typicalPrice >= previousTipycalPrice ? 1 : -1));
if(moneyFlow.Count > period)
{
moneyFlow.Dequeue();
}
if (i < period - 1)
{
i++;
}
else
{
positiveMoneyFlow = moneyFlow.Where(v => v >= 0).Sum();
negativeMoneyFLow = Math.Abs(moneyFlow.Where(v => v < 0).Sum());
moneyFlowRatio = positiveMoneyFlow / negativeMoneyFLow;
moneyFlowIndex = 100 - (100 / (1 + moneyFlowRatio));
AddValue(point.PointDateTime, key, moneyFlowIndex, indicators);
}
previousTipycalPrice = typicalPrice;
}
}
示例4: EnqueueFileList
private void EnqueueFileList(List<RequireFile> fileList, Queue<string> queue, List<string> files)
{
foreach (var file in files)
{
if (!fileList.Where(r => r.Name.ToLower() == file.ToLower()).Any()
&& !queue.Where(r => r.ToLower() == file.ToLower()).Any())
{
queue.Enqueue(file);
}
}
}
示例5: smoothInput
private static Point smoothInput(Point current, Queue<Point> recent, int distance)
{
if (recent.Count == recentCount)
recent.Dequeue();
recent.Enqueue(current);
Point avg = new Point();
var near = recent.Where(point =>
Math.Sqrt(Math.Pow(point.X - current.X, 2) + Math.Pow(point.Y - current.Y, 2)) < distance);
avg.X = near.Sum(point => point.X) / near.Count();
avg.Y = near.Sum(point => point.Y) / near.Count();
return avg;
}
示例6: enqueueNewFiles
private void enqueueNewFiles(IEnumerable<string> files, Queue<string> pendingQueue, List<RequireFile> processedFiles)
{
foreach (var file in files)
{
if (!processedFiles.Where(r => r.Name.ToLower() == file.ToLower()).Any()
&& !pendingQueue.Where(r => r.ToLower() == file.ToLower()).Any())
{
pendingQueue.Enqueue(file);
}
}
}
示例7: CheckForNewAds
protected List<Ad> CheckForNewAds(Action<CheckForNewAdsState> stateChangedCallback, Action<List<Ad>> completedCallback, CancellationToken cancelationToken)
{
var state = new CheckForNewAdsState();
var result = new List<Ad>();
int totalProcessed = 0;
int maxAds = Managers.SettingsManager.GetSettings().CheckForNewAdsMaxAdsCount;
int frameSize = 100;
int minAds = 200;
double minNewAdsInFrame = 0.1;
foreach (var connector in Managers.ConnectorsManager.GetConnectors())
{
Managers.LogEntriesManager.AddItem(SeverityLevel.Information, string.Format("Starting download from {0}.", connector.Id));
int adsCount = 0;
List<Ad> connectorResult = new List<Ad>();
List<Ad> lastAds = Repositories.AdsRepository.GetLastAds(connector.Id, maxAds);
Ad lastAd = lastAds.FirstOrDefault();
DateTime lastCollectionDate = lastAd == null ? DateTime.Now.Date : lastAd.CollectDate.Date;
Queue<bool> frame = new Queue<bool>(frameSize);/*true for new or republished ad, otherwise false*/
try
{
foreach (var ad in connector.GetAds())
{
adsCount++;
totalProcessed++;
var isNewAd = IsNewOrRepublishedAd(ad, lastAds);
state.Progress = totalProcessed;
state.SourceUrl = connector.Id;
state.Canceled = cancelationToken.IsCancellationRequested;
state.Description = "Processing...";
stateChangedCallback(state);
connectorResult.Add(ad);
frame.Enqueue(isNewAd);
if (frame.Count > frameSize)
{
frame.Dequeue();
}
if ((adsCount > minAds && frame.Count == frameSize && ((double)frame.Where(item => item).Count()/(double)frameSize) < minNewAdsInFrame) ||
adsCount >= maxAds || cancelationToken.IsCancellationRequested)
{
break;
}
}
ProcessCollectDate(connectorResult, DateTime.Now);
state.Description = "Analyzing...";
stateChangedCallback(state);
var acceptance = AddNewOrCreateHistory(connectorResult);
Managers.LogEntriesManager.AddItem(SeverityLevel.Information,
string.Format("{0} Collection from {1} finished. Processed: {2}; New ads: {3}; Added to History: {4}; Rejected: {5};",
this.GetType().Name, connector.Id,
acceptance.Count(),
acceptance.Where(a => a == AdAcceptance.Accepted).Count(),
acceptance.Where(a => a == AdAcceptance.History).Count(),
acceptance.Where(a => a == AdAcceptance.Rejected).Count()));
result.AddRange(connectorResult);
}
catch (Exception ex)
{
Managers.LogEntriesManager.AddItem(SeverityLevel.Error,
string.Format("{0} Download error. {1}", this.GetType().Name, ex.Message), ex.StackTrace);
}
if (cancelationToken.IsCancellationRequested)
{
break;
}
}
completedCallback(result);
return result;
}
示例8: PlayField
public string PlayField(Queue<Player> players)
{
string field = "";
Player player;
for (int bit = 1; bit < 512; bit <<= 1) {
player = players.Where (p => (bit & p.Moves) != 0).FirstOrDefault ();
field += player != null ? player.Sign.ToString () : " ";
}
return field;
}
示例9: _02_02_CollectionsGenerischTest
//.........这里部分代码省略.........
{
Debug.WriteLine("preis: " + actNode.Value);
}
// Iterieren über die LinkedList rückwärts
for (actNode = AktuellePreise.Last; actNode != null; actNode = actNode.Previous)
{
Debug.WriteLine("preis: " + actNode.Value);
}
foreach (var p in AktuellePreise)
{
// Current greift auf Value vom Node zu
Debug.WriteLine("preis: " + p);
}
// 2 PReise entfernen
Preisliste.Remove(new Preis(12, 45));
// den 3. Preis entfernen
Preisliste.RemoveAt(3);
AktuellePreise.Clear();
foreach (var p in Preisliste)
{
AktuellePreise.AddLast(p.ToString());
}
// Telefonbuch
var telBuch = new Dictionary<string, int>();
telBuch.Add("Anton", 4711);
// neuer Eintrag hinzugefügt, da noch nicht unter dem Schlüssel vorhanden
// Folgeder Indexeraufruf entspricht telbuch.Add("Berta", 6969);
telBuch["Berta"] = 6969;
// Eintrag geändert
telBuch["Berta"] = 7766;
telBuch["Cäsar"] = 3344;
// Iterieren durch Dictionary 1
var telBuchListe = new LinkedList<string>();
foreach (var k in telBuch.Keys)
{
telBuchListe.AddLast(k + ": " + telBuch[k]);
}
// Iterieren durch Dictionary 2
telBuchListe.Clear();
foreach (KeyValuePair<string, int> pair in telBuch)
{
telBuchListe.AddLast(pair.Key + ": " + pair.Value);
}
// Queue
var Warteschlange = new Queue<Tuple<int, string>>();
// Aufträge in Warteschlange einstellen
Warteschlange.Enqueue(new Tuple<int, string>(99, "Abwaschen"));
Warteschlange.Enqueue(new Tuple<int, string>(77, "Abtrocknen"));
Warteschlange.Enqueue(new Tuple<int, string>(66, "Wegräumen"));
// Jobverarbeitung schaltet sich ein
var Auftragsprotokoll = new LinkedList<string>();
var Auftrag = Warteschlange.Dequeue();
Auftragsprotokoll.AddLast("Führe aus: " + Auftrag.Item2);
Warteschlange.Enqueue(new Tuple<int, string>(55, "Zumachen"));
// Nachschauen, ohne zu entnehmen
var erstes = Warteschlange.Peek();
// Da die Queue IEnumerable implementiert, können alle aktuellen
// Einträge mittels foreach- Schleife besucht werden
foreach (var job in Warteschlange)
{
Debug.WriteLine(job.Item2);
}
var alleJobsDieMitABeginnen = Warteschlange.Where(r => r.Item2.StartsWith("A")).ToArray();
Auftrag = Warteschlange.Dequeue();
Auftragsprotokoll.AddLast("Führe aus: " + Auftrag.Item2);
// Alle restlichen verarbeiten
while (Warteschlange.Count > 0)
{
Auftrag = Warteschlange.Dequeue();
Auftragsprotokoll.AddLast("Führe aus: " + Auftrag.Item2);
}
}
示例10: GetResponse
/// <summary>
/// 用Socket取得遠端列表的(全部/任一)回應
/// </summary>
/// <param name="remoteIpList">遠端目的列表</param>
/// <param name="request">request data</param>
/// <param name="response">response data</param>
/// <param name="waitAll">是否等待所有遠端response</param>
/// <param name="sendTimeout">default: 3 second</param>
/// <param name="receiveTimeout">default: 3 second</param>
/// <returns>true:取得response/false:遠端連線異常</returns>
protected virtual bool GetResponse(IList<IPEndPoint> remoteIpList, byte[] request, out byte[] response,bool waitAll = false, int sendTimeout = 3000, int receiveTimeout = 30000)
{
Queue<Task<byte[]>> resultList = new Queue<Task<byte[]>>();
response = null;
try
{
foreach (IPEndPoint dest in remoteIpList)
{
//task run
Task<byte[]> task = Task.Run(() => { return GetResponse(dest, request, sendTimeout, receiveTimeout); });
//push in task list
resultList.Enqueue(task);
}
if (waitAll)
{
bool complete = Task.WaitAll(resultList.ToArray(), 50000);//timeout: 50 second
//if need compare all result to do that// if need TODO...
//resultList.GroupBy(n => n.Result)....;
//if complete filter result is null and get the first task result
response = complete ? resultList.Where(n => n.Result != null).FirstOrDefault().Result : null;
return complete;
}
else
{
int index = Task.WaitAny(resultList.ToArray(), 50000);//tiemout: 50 second
//if anyone is complete use the return index to find task result
response = index.Equals(-1) ? null : resultList.ElementAtOrDefault(index).Result;
return !index.Equals(-1);
}
}
catch (Exception ex)
{
Console.WriteLine("[GetResponse]Error:" + ex.Message + Environment.NewLine + ex.StackTrace);
return false;
}
}
示例11: RemovePlayer
internal void RemovePlayer(string nick)
{
var before = players.Where(p => p.State != PlayerState.PausedPlaying).Count();
players = new Queue<PokerPlayer>(players.Where(p => p.Nick != nick));
var after = players.Where(p => p.State != PlayerState.PausedPlaying).Count();
if (before == 2 && after == 1)
{
//Game must end, not enough players
ResetGame();
}
}
示例12: Pars
public bool Pars(string modelPath)
{
StreamReader sr = new StreamReader(modelPath);
string data = sr.ReadToEnd();
sr.Close();
MessageParser.NET.Tools.XmlParser xml = new MessageParser.NET.Tools.XmlParser();
string ConceptualSection = xml.GetSubTreeByParent(data, "edmx:StorageModels")[0].InnerXml;
var dic = GetsRoles(ConceptualSection);
var matchesEntityType = xml.GetSubTreeByParent(ConceptualSection, "EntityType");
var entityTypeList = xml.GetSubTreeByParent(ConceptualSection, "EntityType");
var associationList = xml.GetSubTreeByParent(ConceptualSection, "Association");
Queue<struc> result = new Queue<struc>();
Queue<AssociationStruct> associationResult = new Queue<AssociationStruct>();
for (int k = 0; k < associationList.Length; k++)
{
associationResult.Enqueue(GetAssociation(associationList[k].OuterXml));
}
for (int k = 0; k < entityTypeList.Length; k++)
{
{
struc te = new struc();
te.Fname = Filter(xml.GetAttributeValue(entityTypeList[k].OuterXml, "EntityType", "Name"));
te.Props = GetProperty(entityTypeList[k].OuterXml);
te.Map = GetMapForTable(xml.GetSubTreeByParent(data, "edmx:Mappings")[0].InnerXml,te.Fname);
if (result.Where(p => p.Fname == te.Fname).FirstOrDefault() != null)
continue;
if (!string.IsNullOrEmpty(NameSpace))
te.NameSpace = NameSpace;
te.ModelName = te.Map.Name;
te.TableName = te.Map.StoreEntitySet;
te.Fname = "frm" + te.Map.Name;
result.Enqueue(te);
}
}
var filter = Distinct(result.ToArray());
ParsedData = filter;
ProcessAssociation(filter, associationResult.ToArray());
Translate(filter, dic);
FormGenerator generate = new FormGenerator();
var designFile = generate.GenerateFormDesign(filter);
foreach (struc t in designFile)
{
if (File.Exists(OutPutAddress + "\\" + t.Fname + ".Designer.cs"))
File.Delete(OutPutAddress + "\\" + t.Fname + ".Designer.cs");
StreamWriter sw = new StreamWriter(OutPutAddress + "\\" + t.Fname + ".Designer.cs", true);
sw.Write(t.Design);
sw.Close();
}
var efName = regexPatterns.GetMatches(regexPatterns.GetMatch(data, regexPatterns.EntitiyName).Value, regexPatterns.GetValue)[0].Value.Replace('"', ' ').Trim();
CodeGenerator code = new CodeGenerator();
var codeFile = code.GenerateClass(filter, efName);
foreach (struc t in codeFile)
{
if (File.Exists(OutPutAddress + "\\" + t.Fname + ".cs"))
File.Delete(OutPutAddress + "\\" + t.Fname + ".cs");
StreamWriter sw = new StreamWriter(OutPutAddress + "\\" + t.Fname + ".cs", true);
sw.Write(t.Code);
sw.Close();
}
for (int i = 0; i < result.Count; i++)
{
if (File.Exists(OutPutAddress + "\\" + result.ElementAt(i).Fname + ".resx"))
File.Delete(OutPutAddress + "\\" + result.ElementAt(i).Fname + ".resx");
File.Copy(Environment.CurrentDirectory + "\\RFile.resx", OutPutAddress + "\\" + result.ElementAt(i).Fname + ".resx");
}
return true;
}
示例13: Distinct
private struc[] Distinct(struc[] input)
{
Queue<struc> res = new Queue<struc>();
for (int i = 0; i < input.Length; i++)
{
if (res.Where(p => p.Fname == input[i].Fname).FirstOrDefault() == null)
res.Enqueue(input[i]);
}
return res.ToArray();
}