Rumah >pembangunan bahagian belakang >C++ >Bagaimana untuk Menjana Semua Kemungkinan Gabungan daripada Senarai Integer dalam C#?
Senaraikan semua gabungan dalam senarai nilai
Dalam C#, diberikan senarai integer yang dinamik, selalunya perlu untuk menjana semua kemungkinan gabungan elemennya. Contohnya, untuk senarai {1, 2, 3}, anda perlu menjana gabungan berikut:
<code>{1, 2, 3} {1, 2} {1, 3} {2, 3} {1} {2} {3}</code>
Untuk melakukan ini, gunakan algoritma berikut:
Kod C# yang disediakan menunjukkan pelaksanaan algoritma ini:
<code class="language-csharp">static void Main(string[] args) { GetCombination(new List<int> { 1, 2, 3 }); } static void GetCombination(List<int> list) { double count = Math.Pow(2, list.Count); for (int i = 1; i < count; i++) { string binary = Convert.ToString(i, 2).PadLeft(list.Count, '0'); List<int> combination = new List<int>(); for (int j = 0; j < binary.Length; j++) { if (binary[j] == '1') { combination.Add(list[j]); } } Console.WriteLine(string.Join(", ", combination)); } }</code>
Atas ialah kandungan terperinci Bagaimana untuk Menjana Semua Kemungkinan Gabungan daripada Senarai Integer dalam C#?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!