c# - 配列 - 一意のキーと値を持つグループデータ




フォーム間 値 受け渡し c# (2)

私は次のような数字を持っています:

1  137
1  143
11 37
11 46
11 132
46 65
46 139
69 90

今、グループ値にグループキーが存在しないように、最初の値でデータをグループ化する必要があります。 たとえば、データを単純にグループ化する場合、この結果が得られます。

1  137
   143
11 37
   46
   132
46 65
   139
69 90

ここで、46は第3のグループのグループキーであり、第2のグループのグループ値である。 この場合、第3のグループのグループ値を第2のグループにマージし、第3のグループを削除する必要があります。 グループ化の最終結果は次のようになります。

1  137
   143
11 37
   46
   132
   65
   139
69 90

私はC#には比較的新しいので、LINQを使用してそれを行うための素晴らしい方法があるのだろうかと思っていました。


これはあなたのために働くことができる

public static List<Numbers> setNumbers()
{
    List<Numbers> num = new List<Numbers>();

    num.Add(new Numbers() { Column1 = 1, Column2 = 137 });
    num.Add(new Numbers() { Column1 = 1, Column2 = 143 });
    num.Add(new Numbers() { Column1 = 11, Column2 = 37 });
    num.Add(new Numbers() { Column1 = 11, Column2 = 46 });
    num.Add(new Numbers() { Column1 = 11, Column2 = 132 });
    num.Add(new Numbers() { Column1 = 46, Column2 = 65 });
    num.Add(new Numbers() { Column1 = 46, Column2 = 139 });
    num.Add(new Numbers() { Column1 = 69, Column2 = 90 });


    return num;
}


public static void group()
{
    List<Numbers> numbers = setNumbers();

    var grouppedNumbers = numbers
        .GroupBy(x => x.Column1).ToList();

    grouppedNumbers.AddRange(grouppedNumbers.FirstOrDefault(x => x.First().Column1.Equals(46)).Select(s => new Numbers() { Column1 = 11, Column2 = s.Column2 }).GroupBy(g => g.Column1).ToList());
    grouppedNumbers.Remove(grouppedNumbers.FirstOrDefault(x => x.First().Column1.Equals(46)));



    foreach (var groups in grouppedNumbers)
    {
        Console.WriteLine(groups.First().Column1);
       foreach(var i in groups)
       {
           Console.WriteLine(i.Column1+" "+ i.Column2);
       }
    }




}

このLINQソリューションをお試しください:

var numbers = new List<Number>
{
    new Number {X = 1, Y = 137},
    new Number {X = 1, Y = 143},
    new Number {X = 11, Y = 37},
    new Number {X = 11, Y = 46},
    new Number {X = 11, Y = 132},
    new Number {X = 46, Y = 65},
    new Number {X = 46, Y = 139},
    new Number {X = 69, Y = 90}
};
var result = numbers.GroupBy(c => c.X);
var result2 = numbers.FirstOrDefault(c => result.Select(d => d.Key).Contains(c.Y));

var finalResult = numbers.Where(x => x.X == result2?.Y)
                         .Select(x =>  { x.X = result2.X;x.Y = x.Y; return x; } )
                         .Union(numbers.Where(c => c.X != result2?.Y)).GroupBy(c => c.X ,
                         (key, element) => new
                         {
                             Key = key,
                            Element = element.Select(c => c.Y).ToList()
                         });

結果:







group-by