开发者

Get the top nth values from a rectangular array

I am reading a txt file for strings that represent integers. The file is space delimited. I have created an array[10,2]. Everytime the strings 1~10 is found in the file I increment array[n,0] by 1. I also feed array[n,1] with numbers 1~10.

i.e. txt file contents:

1/1/1 10/1/2001 1 1 10 2 2 3 1 5 10 word word 3 3 etc..
  • streamreader reads 1/1/1 and determines that is is not 1~10
  • streamreader reads 10/1/2001 and determines that it is not 1~10
  • streamreader reads 1 and ++array[0,0]
  • streamreader reads 1 and ++array[0,0]
  • streamreader reads 10 and ++array[9,0]
  • etc..

The result will be:

  • '1' was found 3 times
  • '2' was found 2 times
  • '3' was found 3 times
  • '5' was found 1 time
  • '10' was found 2 times

My problem is that I need this array placed in order(sorted) by value of column 0 so that it would be:

1
3
2
10
5

The 2nd column in the array is so I can tell what the original(string that was found the most) was. example: array[0,0]= 5//number of times '1' is found in the txt file array[0,1]=1//this is so i know after the sort that array[0,0] value was for '1' array[1,0]= 10//number of times '2' is found in the txt file array[1,1]= 2//this is so i know after the sort that array[1,0] value was for '2'

before I only had a single deminsional array. When I so开发者_JAVA百科rted the array I had no way of knowing what the original value of array[0] was so I decided to make a rec array so that array[0,1] switches from 1 to 2 so i could know which string actually shows up the most. does this make more since?


As a suggestion, perhaps you might consider using a dictionary of int to int. That way you could support n digit values (rather than a fixed range). Though I'm not sure I understand what else the second dimension of the array is storing?

To output them in order using your current solution, assuming your multi-array called _countsIndexedByValues;

var orderedCounts = _countsIndexedByValues.Select((innerArr, i) => new { Count = innerArr[0], Value = i}).OrderBy(u => u.Count);
orderCounts.ToList().ForEach(u => Console.Out.WriteLine(String.Format("'{0}' was found {1} times", u.Value, u.Count);

This is making use of both LINQ and anonymous types... Where I used an anonymous type you could use a Pair or whatever else you want.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜