本文整理汇总了C#中SortedDictionary.Remove方法的典型用法代码示例。如果您正苦于以下问题:C# SortedDictionary.Remove方法的具体用法?C# SortedDictionary.Remove怎么用?C# SortedDictionary.Remove使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类SortedDictionary
的用法示例。
在下文中一共展示了SortedDictionary.Remove方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: cycle_check
public string cycle_check(SortedDictionary<char, char> cycle)
{
var cycle_str = "A";
var cycle_key = 'A';
var cycle_value = cycle['A'];
var cycle_length = "";
while (cycle.Count != 1)
{
if (cycle_str.IndexOf(cycle_value) != -1)
{
cycle.Remove(cycle_key);
cycle_key = cycle.ElementAt(0).Key;
cycle_value = cycle[cycle_key];
cycle_str += " " + cycle_key.ToString();
}
else
{
cycle_str += cycle_value.ToString();
cycle.Remove(cycle_key);
cycle_key = cycle_value;
cycle_value = cycle[cycle_key];
}
}
foreach (var el in cycle_str.Split(' '))
cycle_length += el.Length + " ";
return cycle_length;
}
示例2: Solve
public long Solve()
{
var primes = new Prime((int)DivisoNumbers);
var sortedPrimes = new SortedDictionary<long, PrimeDivisors>();
foreach (var prime in primes.PrimeList)
{
sortedPrimes.Add(prime, new PrimeDivisors(prime));
}
while (true)
{
var minkey = sortedPrimes.Keys.First();
var maxKey = sortedPrimes.Keys.Last();
var minValue = sortedPrimes[minkey];
var newKey = minkey * minkey;
if (newKey > maxKey)
{
break;
}
sortedPrimes.Add(newKey, minValue.UpdatePower());
sortedPrimes.Remove(minkey);
sortedPrimes.Remove(maxKey);
}
return sortedPrimes.Select(
primeDivisorse => (long)Math.Pow(primeDivisorse.Value.Prime, primeDivisorse.Value.Power) % Modulo
).Aggregate(
1L, (current, coefficient) => (current * coefficient) % Modulo
);
}
示例3: UploadCdnEntity
public string UploadCdnEntity(SortedDictionary<string, object> requestParams)
{
string actionName = "UploadCdnEntity";
string entityFile = requestParams["entityFile"].ToString();
requestParams.Remove("entityFile");
var file = new FileInfo(entityFile);
if (!file.Exists)
{
throw new FileNotFoundException();
}
if (!requestParams.ContainsKey("entityFileMd5"))
{
FileStream md5_file = new FileStream(entityFile, FileMode.Open);
System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
byte[] retVal = md5.ComputeHash(md5_file);
md5_file.Close();
StringBuilder sb = new StringBuilder();
for (int i = 0; i < retVal.Length; i++)
{
sb.Append(retVal[i].ToString("x2"));
}
requestParams["entityFileMd5"] = sb.ToString();
}
return Call(actionName, requestParams, entityFile);
}
示例4: Main
private static void Main()
{
string readLine = Console.ReadLine();
SortedDictionary<char, int> countsOfChars = new SortedDictionary<char, int>();
int count = 1;
for (int i = 0; i < readLine.Length; i++)
{
if (countsOfChars.ContainsKey(readLine[i]))
{
int value = countsOfChars[readLine[i]];
countsOfChars.Remove(readLine[i]);
countsOfChars.Add(readLine[i], count + value);
}
else
{
countsOfChars.Add(readLine[i], count);
}
}
foreach (KeyValuePair<char, int> p in countsOfChars)
{
Console.WriteLine("{0}: {1} time/s", p.Key, p.Value);
}
}
示例5: KwayMerge
private static void KwayMerge(IEnumerable<string> chunkFilePaths, string resultFilePath)
{
var chunkReaders = chunkFilePaths
.Select(path => new StreamReader(path))
.Where(chunkReader => !chunkReader.EndOfStream)
.ToList();
var sortedDict = new SortedDictionary<string, TextReader>();
chunkReaders.ForEach(chunkReader => sortedDict.Add(chunkReader.ReadLine(), chunkReader));
using (var resultWriter = new StreamWriter(resultFilePath, false))
while (sortedDict.Any())
{
var line = sortedDict.Keys.First();
var chunkReader = sortedDict[line];
sortedDict.Remove(line);
resultWriter.WriteLine(line);
var nextLine = chunkReader.ReadLine();
if (nextLine != null)
{
sortedDict.Add(nextLine, chunkReader);
}
else
{
chunkReader.Dispose();
}
}
}
示例6: Main
private static void Main()
{
Queue<string> grad = new Queue<string>();
SortedDictionary<string, string> venueAndEvent = new SortedDictionary<string, string>();
while (true)
{
string[] readLineComand = Console.ReadLine().Split(';').ToArray();
if (readLineComand[0] == "END")
{
for (int i = 0; i < grad.Count; i++)
{
Console.WriteLine(grad.Peek());
foreach (KeyValuePair<string, string> p in venueAndEvent)
{
Console.WriteLine("->{0}: {1}", p.Key, p.Value);
}
}
return;
}
if (venueAndEvent.ContainsKey(readLineComand[1]))
{
string value = venueAndEvent[readLineComand[1]];
venueAndEvent.Remove(readLineComand[1]);
venueAndEvent.Add(readLineComand[1], value + value);
}
else if (true)
{
grad.Enqueue(readLineComand[0]);
venueAndEvent.Add(readLineComand[1], readLineComand[2]);
}
}
}
示例7: bNear_Click
private void bNear_Click(object sender, RoutedEventArgs e) {
SortedDictionary<string, string> d = new SortedDictionary<string, string>();
foreach (string k in Settings.Default.Dirs.Split('\n')) d[k] = null;
d[Pics] = null;
d.Remove("");
Directory.CreateDirectory(Pics);
Settings.Default.Dirs = String.Join("\n", d.Keys.ToArray());
Process.Start(Pics);
}
示例8: CalculateMedianSum
public static int CalculateMedianSum(int[] numbers)
{
int medianSum = 0;
var lowHeap = new SortedDictionary<int, int>();
var highHeap = new SortedDictionary<int, int>();
lowHeap.Add(numbers[0],0);
medianSum += numbers[0];
for (int index = 1; index < numbers.Length; index++)
{
int lowHeapMax = lowHeap.Last().Key;
int current = numbers[index];
// update heaps
if (current < lowHeapMax)
{
lowHeap.Add(current,0);
}
else
{
highHeap.Add(current, 0);
}
bool mayRequireBalancing = (index + 1)%2 == 0;
// balancing
if (mayRequireBalancing && lowHeap.Count != highHeap.Count)
{
if (lowHeap.Count > highHeap.Count)
{
lowHeapMax = lowHeap.Last().Key;
lowHeap.Remove(lowHeapMax);
highHeap.Add(lowHeapMax, 0);
}
else
{
int highHeapMin = highHeap.First().Key;
highHeap.Remove(highHeapMin);
lowHeap.Add(highHeapMin, 0);
}
}
// calculate median
if (lowHeap.Count >= highHeap.Count)
{
medianSum += lowHeap.Last().Key;
}
else
{
medianSum += highHeap.First().Key;
}
}
return medianSum;
}
示例9: GetShortestPath
public NavPoint[] GetShortestPath(NavPoint start, NavPoint target)
{
HashSet<NavPoint> visited = new HashSet<NavPoint>();
SortedDictionary<float,NavPoint> pq = new SortedDictionary<float, NavPoint>();
Dictionary<NavPoint,NavPoint> cameFrom = new Dictionary<NavPoint, NavPoint>();
Dictionary<NavPoint,float> scores = new Dictionary<NavPoint, float>();
pq.Add(Vector3.Distance(target.position,start.position),start);
scores.Add(start,Vector3.Distance(target.position,start.position));
while(pq.Count > 0)
{
SortedDictionary<float,NavPoint>.KeyCollection.Enumerator keyEnumer = pq.Keys.GetEnumerator();
keyEnumer.MoveNext();
NavPoint np = pq[keyEnumer.Current];
pq.Remove(keyEnumer.Current);
if(IsGoal(np, target))
return ReconstructPath(cameFrom,np);
visited.Add(np);
foreach(NavPoint neighbour in np.neighbours)
{
if(neighbour.gameObject.activeInHierarchy)
{
if(visited.Contains(neighbour))
continue;
float estimate = scores[np] + Vector3.Distance(np.position,neighbour.position);
//if this is the first time we've seen this node
//or if we have a found a shorter path to it
if(!pq.ContainsValue(neighbour) || (scores.ContainsKey(neighbour) && estimate < scores[neighbour])) {
cameFrom[neighbour] = np;
scores[neighbour] = estimate;
try
{
pq.Add(estimate + Vector3.Distance(neighbour.position,target.position),neighbour);
} catch (System.ArgumentException e) {
//this means the key already exists i.e. there is already a distance that is this value
//this is real bad for A* that we can't have two things of the same priority but I'm just going
//to ignore it because GAME JAM
pq.Add(estimate + Vector3.Distance(neighbour.position,target.position)+Random.value/100,neighbour);
}
}
}
}
}
return null;
}
示例10: RemoveDuplicateLetters
public string RemoveDuplicateLetters(string s)
{
StringBuilder sb = new StringBuilder();
SortedDictionary<char, List<int>> dict = new SortedDictionary<char, List<int>>();
int j = 0;
foreach (char c in s)
{
List<int> list;
if (!dict.TryGetValue(c, out list))
{
dict.Add(c, list = new List<int>());
}
list.Add(j++);
}
SortedSet<int> set = new SortedSet<int>();
foreach (var pair in dict)
{
set.Add(pair.Value[pair.Value.Count - 1]);
}
int pos = -1;
char last = default(char);
while (dict.Count > 0)
{
foreach (var pair in dict)
{
int p = pair.Value[-1 * (pair.Value.BinarySearch(pos) + 1)];
if (p <= set.Min)
{
sb.Append(pair.Key);
pos = p;
last = pair.Key;
set.Remove(pair.Value[pair.Value.Count - 1]);
break;
}
}
dict.Remove(last);
}
return sb.ToString();
}
示例11: ShortestProcessNext
/// <summary>
/// initiates the object and runs the scheduler on given processes.
/// </summary>
/// <param name="pList">List of processes</Process></param>
/// <param name="quantumTime">represented in seconds</param>
public ShortestProcessNext(List<Process> pList, double quantumTime)
{
this.pList = pList.OrderBy(o => o.ArrivalTime).ToList();
TimeSpan currentTime = this.pList[0].ArrivalTime;
List<Process> tmplist = new List<Process>(this.pList);
arrivedPList = new SortedDictionary<TimeSpan, Process>();
log = new Logger();
while (tmplist.Count > 0 && tmplist[0].ArrivalTime <= currentTime)
{
arrivedPList.Add(tmplist[0].ServiceTime - tmplist[0].SpentTime, tmplist[0]);
tmplist.RemoveAt(0);
}
while (tmplist.Count > 0 || arrivedPList.Count > 0)
{
if (arrivedPList.Count > 0)
{
Process p = arrivedPList[arrivedPList.Keys.Min()];
arrivedPList.Remove(arrivedPList.Keys.Min());
if (!p.Started)
{
p.StartTime = currentTime;
p.Started = true;
}
TimeSpan spenttime = TimeSpan.FromSeconds(quantumTime);
p.SpentTime += spenttime;
log.Log(currentTime, p.Pid.ToString(), p.SpentTime, (p.ServiceTime >= p.SpentTime) ? (p.ServiceTime - p.SpentTime) : TimeSpan.FromSeconds(0));
currentTime += spenttime;
if (p.SpentTime >= p.ServiceTime)
p.EndTime = p.StartTime + p.SpentTime;
else
arrivedPList.Add(p.ServiceTime - p.SpentTime, p);
}
else
currentTime = tmplist[0].ArrivalTime;
while (tmplist.Count > 0 && tmplist[0].ArrivalTime <= currentTime)
{
arrivedPList.Add(tmplist[0].ServiceTime - tmplist[0].SpentTime, tmplist[0]);
tmplist.RemoveAt(0);
}
}
}
示例12: findSum
public long findSum(int[] m, int R)
{
List<int> desc = new List<int>();
for (int i = 0; i < m.Length; i++)
{
if (i == 0 || m[i] < desc[desc.Count - 1]) { desc.Add(m[i]); }
}
SortedDictionary<int, List<int>> resets =new SortedDictionary<int, List<int>>();
foreach (int i in desc)
{
var basis = new List<int>();
basis.Add(i);
resets.Add(i, basis);
}
int curMin = desc[desc.Count - 1];
int val = 1;
long total = 0;
for (int i = 1; i <= R; i++)
{
if (i == curMin)
{
val = 0;
List<int> basis = resets[curMin];
resets.Remove(curMin);
foreach (int b in basis)
{
List<int> other;
if (!resets.TryGetValue(curMin + b, out other))
{
other = new List<int>();
resets[curMin + b] = other;
}
other.Add(b);
}
curMin = resets.First().Key;
}
total += val;
val++;
}
return total;
}
示例13: Main
static void Main()
{
var courses = new SortedDictionary<string, List<Student>>();
string separator = " | ";
var filePath = "../../../students.txt";
using (StreamReader reader = new StreamReader(filePath))
{
while (!reader.EndOfStream)
{
var line = reader.ReadLine();
var courseStartIndex = line.LastIndexOf(separator) + separator.Length;
var course = line.Substring(courseStartIndex, line.Length - courseStartIndex).Trim();
var familyNameStartIndex = line.IndexOf(separator) + separator.Length;
var familyNameLength = line.Length - course.Length - separator.Length - familyNameStartIndex;
var familyName = line.Substring(familyNameStartIndex, familyNameLength).Trim();
var firstName = line.Substring(0, familyNameStartIndex - separator.Length).Trim();
var students = new List<Student>();
if (courses.ContainsKey(course))
{
students = courses[course];
}
var student = new Student(firstName, familyName);
students.Add(student);
courses.Remove(course);
courses.Add(course, students);
}
foreach (var pair in courses)
{
var students = pair.Value.OrderBy(s => s.FamilyName).ThenBy(s => s.FirstName).ToList();
Console.WriteLine("{0} : {1}", pair.Key, string.Join(", ", students));
}
}
}
示例14: Main
public static void Main()
{
// Read the input
Console.WriteLine("Enter amount");
int amount = int.Parse(Console.ReadLine());
Console.WriteLine("Enter number of types of coins");
int typeOfCoins = int.Parse(Console.ReadLine());
SortedDictionary<int, int> coins = new SortedDictionary<int, int>();
Console.WriteLine("Enter type of coin and its number separated by space");
for (int count = 0; count < typeOfCoins; count++)
{
string input = Console.ReadLine();
string[] inputData = input.Split(' ');
coins.Add(int.Parse(inputData[0]), int.Parse(inputData[1]));
}
// Get each time from the bigger possible coin type
// Till there are more coins and did not ecxeeded the amount
Dictionary<int, int> used = new Dictionary<int, int>();
while (coins.Count > 0 && amount > 0)
{
int maxType = coins.Keys.Max();
int maxNumber = coins[maxType];
used.Add(maxType, 0);
while (coins[maxType] > 0 && amount >= maxType)
{
amount -= maxType;
coins[maxType]--;
used[maxType]++;
}
coins.Remove(maxType);
}
foreach (var item in used)
{
Console.WriteLine("{0} coin {1} times = {2}", item.Key, item.Value, item.Key * item.Value);
}
}
示例15: CheckSignature
//Check hash-sum
public bool CheckSignature(Dictionary<string, string> formDictionary)
{
Int32 w1PaymentNo;
SortedDictionary<string, string> sortedFormMd5Dictionary;
StringBuilder strValues;
string signature, message, tmpStr, decodedUrl;
CodeUtils codeUtils;
byte[] bytes, hash;
sortedFormMd5Dictionary = new SortedDictionary<string, string>(
formDictionary);
w1PaymentNo = Convert.ToInt32(sortedFormMd5Dictionary["WMI_PAYMENT_NO"]);
//сигнатура не нужна в вычислении
sortedFormMd5Dictionary.Remove("WMI_SIGNATURE");
codeUtils = new CodeUtils();
strValues = new StringBuilder();
foreach (var key in sortedFormMd5Dictionary.Keys)
{
//Очень, очень важно расшифровать строку (UrlDecode). Так как входные
//данные пришли из формы с атрибутом
//this.Request.ContentType = "application/x-www-form-urlencoded"
//Даже несмотря на то, что входные данные в charset = UTF-8
decodedUrl = HttpUtility.UrlDecode(sortedFormMd5Dictionary[key]);
strValues.Append(decodedUrl);
}
//не забыли сделать конкатенацию секретного ключа
message = strValues.ToString() + SpecialConstants.MERCHANT_KEY;
//получили MD5-подпись всех(кроме signature) полей post-формы
bytes = Encoding.GetEncoding(1251).GetBytes(message);
hash = new MD5CryptoServiceProvider().ComputeHash(bytes);
signature = Convert.ToBase64String(hash);
if (signature == HttpUtility.UrlDecode(formDictionary["WMI_SIGNATURE"]))
return true; //подписи совпали
//либо отправитель злоумышленник, либо ошибка программиста
else return false;
}