Guest User

Untitled

a guest
May 5th, 2015
607
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C# 1.42 KB | None | 0 0
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. class SubsetSums
  5. {
  6.     static void Main()
  7.     {
  8.         // input
  9.         Console.Write("Enter sum = ");
  10.         int sum = int.Parse(Console.ReadLine());
  11.         Console.WriteLine("Enter numbers separated by a space:");
  12.         int[] numbers = Console.ReadLine().Split(' ').Select(int.Parse).ToArray();
  13.         // remove duplicates
  14.         List<int> noDuplicates = numbers.ToList();
  15.         noDuplicates = noDuplicates.Distinct().ToList();
  16.         // generate subsets
  17.         var subsets = from m in Enumerable.Range(0, 1 << noDuplicates.Count)
  18.                       select
  19.                           from i in Enumerable.Range(0, noDuplicates.Count)
  20.                           where (m & (1 << i)) != 0
  21.                           select noDuplicates[i];
  22.         // check subsets' sums and print them
  23.         bool noOutput = true;
  24.         Console.WriteLine("Output:");
  25.         foreach (var item in subsets)
  26.         {
  27.             int sumTemp = 0;
  28.             foreach (var number in item)
  29.             {
  30.                 sumTemp += Convert.ToInt32(number);
  31.             }
  32.             if (sumTemp == sum && item.Count() > 0)
  33.             {
  34.                 Console.WriteLine(string.Join(" + ", item) + " = {0}", sum);
  35.                 noOutput = false;
  36.             }
  37.         }
  38.         if (noOutput)
  39.             Console.WriteLine("No matching subsets.");      
  40.     }
  41. }
Advertisement
Add Comment
Please, Sign In to add comment