Advertisement
APXOHT

Untitled

Jan 6th, 2013
289
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C# 1.71 KB | None | 0 0
  1. using System;
  2. using System.Collections.Generic;
  3.  
  4. class SubsetNKS
  5. {
  6.     static void Main()
  7.     {
  8.         Console.Write("Enter N: ");
  9.         int N = int.Parse(Console.ReadLine());
  10.         int[] array = new int[N];
  11.         for (int i = 0; i < N; i++)
  12.         {
  13.             Console.Write("Enter array element {0}: ", i);
  14.             array[i] = int.Parse(Console.ReadLine());
  15.         }
  16.         Console.Write("Enter S: ");
  17.         int S = int.Parse(Console.ReadLine());
  18.         Console.Write("Enter K: ");
  19.         int K = int.Parse(Console.ReadLine());
  20.  
  21.         int checkedNumbers = 0;
  22.         List<int> subsetNumbers = new List<int>();
  23.         int maxi = (int)Math.Pow(2, array.Length) - 1;
  24.         bool hasSubsetSum = false;
  25.  
  26.         for (int i = 1; i <= maxi; i++)
  27.         {
  28.             long currentSum = 0;
  29.             for (int j = 1; j <= array.Length; j++)
  30.             {
  31.                 if (((i >> (j - 1)) & 1) == 1)
  32.                 {
  33.                     currentSum += array[j - 1];
  34.                     checkedNumbers++;
  35.                     subsetNumbers.Add(array[j - 1]);
  36.                 }
  37.             }
  38.             if (checkedNumbers == K && currentSum == S)
  39.             {
  40.                 hasSubsetSum = true;
  41.                 break;
  42.             }
  43.             else
  44.             {
  45.                 checkedNumbers = 0;
  46.                 subsetNumbers.Clear();
  47.             }
  48.         }
  49.  
  50.         if (hasSubsetSum)
  51.         {
  52.             for (int i = 0; i < subsetNumbers.Count; i++)
  53.             {
  54.                 Console.Write(subsetNumbers[i] + " ");
  55.             }
  56.         }
  57.         else
  58.         {
  59.             Console.Write("No such subset.");
  60.         }
  61.         Console.WriteLine();
  62.     }
  63. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement