本文整理汇总了C#中SortedList.OrderByDescending方法的典型用法代码示例。如果您正苦于以下问题:C# SortedList.OrderByDescending方法的具体用法?C# SortedList.OrderByDescending怎么用?C# SortedList.OrderByDescending使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类SortedList
的用法示例。
在下文中一共展示了SortedList.OrderByDescending方法的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: GetCount
public FreqResult GetCount(IEnumerable<string> words)
{
var uniqueWords = new SortedList<string, int>();
foreach (var word in words)
{
if (uniqueWords.ContainsKey(word))
{
uniqueWords[word]++;
}
else
{
uniqueWords.Add(word, 1);
}
}
var result = uniqueWords.OrderByDescending(pair => pair.Value).ToArray();
return new FreqResult(uniqueWords.Count, result.Take(10));
}
示例2: BruteForceMainNoTrades
/// <summary>
/// Tries all possibilities for main teams, picks the best one
/// </summary>
/// <param name="limit">Number of players to consider</param>
public void BruteForceMainNoTrades(int limit)
{
errorwriter.Write("Starting brute force solution with " + limit + " players");
string selectedTeam = string.Empty;
string[] selectedPlayers = new string[6];
int totalPoints = 0;
// Sort players by point total
SortedList<string, int> playerPointComparison = new SortedList<string, int>();
for (int i = 0; i < playerList.Count; i++)
{
playerPointComparison.Add(playerList.Keys.ElementAt(i), playerList.ElementAt(i).Value.TotalPoints);
}
var playerPointSorted = playerPointComparison.OrderByDescending(l => l.Value);
if (limit > playerPointSorted.Count())
{
limit = playerPointSorted.Count();
}
// Sort players by cost
SortedList<string, int> playerCostComparison = new SortedList<string, int>();
for (int i = 0; i < limit; i++)
{
playerCostComparison.Add(playerList.Keys.ElementAt(i), playerList.ElementAt(i).Value.Cost);
}
var playerCostSorted = playerCostComparison.OrderByDescending(l => l.Value);
// The goal is to iterate through the list of players in order of increasing cost
// Thus, when the cost goes over the allowed limit, we can safely ignore all other entries in the list
string[] players = new string[6];
int tcost = 0;
int p1cost = 0;
int p2cost = 0;
int p3cost = 0;
int p4cost = 0;
int p5cost = 0;
int p6cost = 0;
int possibleTeams = 0;
// Loop for team
for (int i0 = 0; i0 < teamList.Count; i0++)
{
string team = teamList.ElementAt(i0).Key;
tcost = teamList[team].Cost;
ProgressUpdate(i0 * 100 / teamList.Count());
// Nest loops for all six players
for (int i1 = playerCostSorted.Count() - 1; i1 >= 5; i1--)
{
players[0] = playerCostSorted.ElementAt(i1).Key;
p1cost = playerList[players[0]].Cost;
if (DoNotDraftFailed(players[0], true))
{
continue;
}
for (int i2 = i1 - 1; i2 >= 4; i2--)
{
players[1] = playerCostSorted.ElementAt(i2).Key;
if (DoNotDraftFailed(players[1], true))
{
continue;
}
p2cost = playerList[players[1]].Cost;
for (int i3 = i2-1; i3 >= 3; i3--)
{
players[2] = playerCostSorted.ElementAt(i3).Key;
if (DoNotDraftFailed(players[2], true))
{
continue;
}
p3cost = playerList[players[2]].Cost;
if (tcost + p1cost + p2cost + p3cost > MAINCOSTLIMIT)
{
break;
}
for (int i4 = i3 - 1; i4 >= 2; i4--)
{
players[3] = playerCostSorted.ElementAt(i4).Key;
if (DoNotDraftFailed(players[3], true))
{
continue;
}
p4cost = playerList[players[3]].Cost;
//.........这里部分代码省略.........
示例3: BestTeamGenerationWithTrades
public void BestTeamGenerationWithTrades(int maxPlayers)
{
errorwriter.Write("Starting brute force solution with trades");
if (maxPlayers > playerList.Count)
{
maxPlayers = playerList.Count;
}
List<string> bestPlayers = FindBestPlayersPerWeek(maxWeeks, maxPlayers);
errorwriter.Write("Picking best " + maxPlayers + " players per week. " + bestPlayers.Count + " players total.");
string[] selectedTeam = new string[maxWeeks];
string[][] selectedPlayers = new string[maxWeeks][];
string[] team = new string[6];
string[][] players = new string[maxWeeks][];
string[] potentialTeam = new string[6];
string[][] potentialPlayers = new string[maxWeeks][];
int bestResult = 0;
for (int i=0; i<maxWeeks;i++)
{
selectedPlayers[i] = new string[6];
players[i] = new string[6];
potentialPlayers[i] = new string[6];
}
errorwriter.Write("Sorting by point gain per week");
// Sort players by point gain per week
SortedList<string, int> playerPointComparison = new SortedList<string, int>();
for (int i = 0; i < bestPlayers.Count; i++)
{
playerPointComparison.Add(bestPlayers[i], playerList.ElementAt(i).Value.TotalPoints);
}
var playerPointSorted = playerPointComparison.OrderByDescending(l => l.Value);
errorwriter.Write("Sorting by cost");
// Sort players by cost
SortedList<string, int> playerCostComparison = new SortedList<string, int>();
for (int i = 0; i < bestPlayers.Count; i++)
{
playerCostComparison.Add(playerPointSorted.ElementAt(i).Key, playerList[playerPointSorted.ElementAt(i).Key].Cost);
}
var playerCostSorted = playerCostComparison.OrderByDescending(l => l.Value);
errorwriter.Write("Sorting by trade value");
// Sort players by trade value
SortedList<string, double>[] playerTradeComparison = new SortedList<string, double>[maxWeeks];
for (int i = 0; i < maxWeeks; i++)
{
playerTradeComparison[i] = new SortedList<string, double>();
for (int j = 0; j < bestPlayers.Count; j++)
{
playerTradeComparison[i].Add(playerPointSorted.ElementAt(j).Key, playerList[playerPointSorted.ElementAt(j).Key].AdjustedTradeValue(i+1));
}
}
IOrderedEnumerable<KeyValuePair<string, double>>[] playerTradeSorted = new IOrderedEnumerable<KeyValuePair<string,double>>[maxWeeks];
for (int i = 0; i < maxWeeks; i++)
{
playerTradeSorted[i] = playerTradeComparison[i].OrderByDescending(l => l.Value);
}
// Sort teams by trade value
SortedList<string, double>[] teamTradeComparison = new SortedList<string, double>[maxWeeks];
for (int i = 0; i < maxWeeks; i++)
{
teamTradeComparison[i] = new SortedList<string,double>();
for (int j = 0; j < 6; j++)
{
teamTradeComparison[i].Add(teamList.ElementAt(j).Key, teamList.ElementAt(j).Value.AdjustedTradeValue(i+1));
}
}
IOrderedEnumerable<KeyValuePair<string, double>>[] teamTradeSorted = new IOrderedEnumerable<KeyValuePair<string, double>>[6];
for (int i = 0; i < maxWeeks; i++)
{
teamTradeSorted[i] = teamTradeComparison[i].OrderByDescending(l => l.Value);
}
// The goal is to iterate through the list of players in order of increasing cost
// Thus, when the cost goes over the allowed limit, we can safely ignore all other entries in the list
// and continue the loop
int tcost = 0;
int p1cost = 0;
int p2cost = 0;
int p3cost = 0;
int p4cost = 0;
int p5cost = 0;
int p6cost = 0;
// Loop for team
for (int i0 = 0; i0 < teamList.Count; i0++)
{
//.........这里部分代码省略.........
示例4: BestMainWithoutTrades
/// <summary>
/// Determines the highest scoring team without trades through algorithm use
/// </summary>
public void BestMainWithoutTrades()
{
string selectedTeam;
string[] selectedPlayers = new string[6];
Dictionary<chosenTeam, int> solutions = new Dictionary<chosenTeam, int>();
// Sort players by point total
SortedList<string, int> playerPointComparison = new SortedList<string, int>();
for (int i = 0; i < playerList.Count; i++)
{
playerPointComparison.Add(playerList.Keys.ElementAt(i), playerList.ElementAt(i).Value.TotalPoints);
}
var playerPointSorted = playerPointComparison.OrderByDescending(l => l.Value);
// Iterate through the list with each team since there's only eight of them
errorwriter.Write("Calculating best team with no trades");
for (int i = 0; i < teamList.Count; i++)
{
selectedTeam = teamList.ElementAt(i).Key;
errorwriter.Write("Using " + selectedTeam);
// Take the highest scoring players
for (int j = 0; j < 6; j++)
{
selectedPlayers[j] = playerPointSorted.ElementAt(j).Key;
}
// The next player in playerPointSorted
int index = 5;
// The cost of the team needs to be reduced to 30 or less
while (MainCostRequirementCheck(selectedPlayers, selectedTeam) > 0 && index < playerList.Count)
{
// Find the player with the lowest point to cost ratio
int lowestCostBenefitPlayer = 0;
for (int j = 1; j < 6; j++)
{
if (playerList[selectedPlayers[j]].PointToCostRatio < playerList[selectedPlayers[lowestCostBenefitPlayer]].PointToCostRatio)
{
lowestCostBenefitPlayer = j;
}
}
// Replace the lowest cost benefit player with the next player in the list, but only if their cost is lower
while (true)
{
index++;
if (index >= playerList.Count)
{
errorwriter.Write("Error during best team determination: index became greater than playerList.Count");
break;
}
string targetPlayer = playerPointSorted.ElementAt(index).Key;
if (playerList[targetPlayer].Cost < playerList[selectedPlayers[lowestCostBenefitPlayer]].Cost)
{
errorwriter.Write("Swapping " + selectedPlayers[lowestCostBenefitPlayer] + " with " + targetPlayer + " (Reducing cost)");
selectedPlayers[lowestCostBenefitPlayer] = targetPlayer;
break;
}
}
}
// Replace players with lower cost equivalents if available
for (int j = 0; j < 6; j++)
{
for (int k = 0; k < playerPointSorted.Count(); k++)
{
if (playerPointSorted.ElementAt(k).Value == playerList[selectedPlayers[j]].TotalPoints)
{
// Note that replacing a player with the same player is impossible since their costs will be the same
if (playerList[playerPointSorted.ElementAt(k).Key].Cost < playerList[selectedPlayers[j]].Cost)
{
bool duplicate = false;
// Avoid duplicates
for (int l = 0; l < 6; l++)
{
if (playerPointSorted.ElementAt(k).Key == selectedPlayers[l])
{
duplicate = true;
}
}
if (!duplicate)
{
errorwriter.Write("Swapping " + selectedPlayers[j] + " with " + playerPointSorted.ElementAt(k).Key + " (Minimizing cost)");
selectedPlayers[j] = playerPointSorted.ElementAt(k).Key;
}
}
}
else if (playerPointSorted.ElementAt(k).Value < playerList[selectedPlayers[j]].TotalPoints)
{
break;
}
//.........这里部分代码省略.........
示例5: BestAntiGenerationWithTrades
public void BestAntiGenerationWithTrades(int maxPlayers)
{
errorwriter.Write("Starting brute force anti with trades");
if (maxPlayers > playerList.Count)
{
maxPlayers = playerList.Count;
}
List<string> bestPlayers = FindWorstPlayersPerWeek(maxWeeks, maxPlayers);
errorwriter.Write("Picking worst " + maxPlayers + " players per week. " + bestPlayers.Count + " players total.");
string[][] selectedPlayers = new string[maxWeeks][];
string[][] players = new string[maxWeeks][];
string[][] potentialPlayers = new string[maxWeeks][];
int bestResult = -99;
for (int i = 0; i < maxWeeks; i++)
{
selectedPlayers[i] = new string[3];
players[i] = new string[3];
potentialPlayers[i] = new string[3];
}
errorwriter.Write("Sorting by point gain per week");
// Sort players by point gain per week
SortedList<string, int>[] playerPointComparison = new SortedList<string, int>[maxWeeks];
for (int i = 0; i < maxWeeks; i++)
{
playerPointComparison[i] = new SortedList<string, int>();
for (int j = 0; j < bestPlayers.Count; j++)
{
playerPointComparison[i].Add(bestPlayers[j], playerList.ElementAt(j).Value.Points(i));
}
}
IOrderedEnumerable<KeyValuePair<string, int>>[] playerPointSorted = new IOrderedEnumerable<KeyValuePair<string, int>>[maxWeeks];
for (int i = 0; i < maxWeeks; i++)
{
playerPointSorted[i] = playerPointComparison[i].OrderByDescending(l => l.Value);
}
errorwriter.Write("Sorting by cost");
// Sort players by cost
SortedList<string, int> playerCostComparison = new SortedList<string, int>();
for (int i = 0; i < bestPlayers.Count; i++)
{
playerCostComparison.Add(bestPlayers[i], playerList[bestPlayers[i]].Cost);
}
var playerCostSorted = playerCostComparison.OrderByDescending(l => l.Value);
errorwriter.Write("Sorting by trade value");
// Sort players by trade value
SortedList<string, double>[] playerTradeComparison = new SortedList<string, double>[maxWeeks];
for (int i = 0; i < maxWeeks; i++)
{
playerTradeComparison[i] = new SortedList<string, double>();
for (int j = 0; j < bestPlayers.Count; j++)
{
playerTradeComparison[i].Add(bestPlayers[j], playerList[bestPlayers[j]].AdjustedTradeValue(i+1));
}
}
IOrderedEnumerable<KeyValuePair<string, double>>[] playerTradeSorted = new IOrderedEnumerable<KeyValuePair<string, double>>[maxWeeks];
for (int i = 0; i < maxWeeks; i++)
{
playerTradeSorted[i] = playerTradeComparison[i].OrderByDescending(l => l.Value);
}
// The goal is to iterate through the list of players in order of increasing cost
// Thus, when the cost goes over the allowed limit, we can safely ignore all other entries in the list
// and continue the loop
int p1cost = 0;
int p2cost = 0;
int p3cost = 0;
// Nest loops for all three players
for (int i1 = playerCostSorted.Count() - 1; i1 >= 2; i1--)
{
ProgressUpdate((playerCostSorted.Count() - i1) * 100 / playerCostSorted.Count());
players[0][0] = playerCostSorted.ElementAt(i1).Key;
p1cost = playerList[players[0][0]].Cost;
if (DoNotDraftFailed(players[0][0], true))
{
continue;
}
for (int i2 = i1 - 1; i2 >= 1; i2--)
{
players[0][1] = playerCostSorted.ElementAt(i2).Key;
if (DoNotDraftFailed(players[0][1], true))
{
continue;
}
//.........这里部分代码省略.........
示例6: FindWorstPlayersPerWeek
private List<string> FindWorstPlayersPerWeek(int weeks, int maxPlayers)
{
List<string> results = new List<string>();
for (int w = 0; w < weeks; w++)
{
// Sort players by points
SortedList<string, int> playerPointComparison = new SortedList<string, int>();
for (int i = 0; i < playerList.Count; i++)
{
playerPointComparison.Add(playerList.Keys.ElementAt(i), playerList.ElementAt(i).Value.Points(w));
}
var sortedplayers = playerPointComparison.OrderByDescending(l => l.Value);
for (int i = playerPointComparison.Count - 1; i >= playerPointComparison.Count - maxPlayers; i--)
{
if (!results.Contains(sortedplayers.ElementAt(i).Key))
{
results.Add(sortedplayers.ElementAt(i).Key);
}
}
}
return results;
}