Advertisement
stanevplamen

03.01.02.ColorRabbits

Jul 1st, 2013
64
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C# 1.60 KB | None | 0 0
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Numerics;
  4.  
  5. class ColorRabbits
  6. {
  7.     static void Main()
  8.     {
  9.         int numberOfRabbits = int.Parse(Console.ReadLine());
  10.         int[] inputArr = new int[numberOfRabbits];
  11.         for (int i = 0; i < numberOfRabbits; i++)
  12.         {
  13.             inputArr[i] = int.Parse(Console.ReadLine());
  14.         }
  15.  
  16.         //int[] inputArr = { 2,2,44,2,2,2,444,2,2 };
  17.  
  18.         Dictionary<int, int> answersDict = new Dictionary<int, int>();
  19.         int temp = 0;
  20.         int currentKey = 0;
  21.         for (int i = 0; i < inputArr.Length; i++)
  22.         {
  23.             bool exists = false;
  24.             foreach (KeyValuePair<int, int> kvp in answersDict)
  25.             {
  26.                 if (kvp.Key == inputArr[i])
  27.                 {
  28.                     exists = true;
  29.                     temp = kvp.Value + 1;
  30.                     currentKey = kvp.Key;
  31.                 }
  32.             }
  33.             if (exists == false)
  34.             {
  35.                 answersDict.Add(inputArr[i], 1);
  36.             }
  37.             else if (exists == true)
  38.             {
  39.                 answersDict[inputArr[i]] = temp;
  40.             }
  41.  
  42.         }
  43.  
  44.         BigInteger result = 0;
  45.         foreach (KeyValuePair<int, int> kvp in answersDict)
  46.         {
  47.             int tempDevide = kvp.Value / (kvp.Key + 1);
  48.             int tempRemainder = kvp.Value % (kvp.Key + 1);
  49.             if (tempRemainder != 0)
  50.             {
  51.                 tempDevide++;
  52.             }
  53.             result = result + (kvp.Key + 1) * tempDevide;
  54.         }
  55.         Console.WriteLine(result);
  56.     }
  57.  
  58. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement