georgimanov

RollBits

Apr 14th, 2014
209
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C# 3.19 KB | None | 0 0
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6.  
  7. namespace _4.Problem_4
  8. {
  9.     class Program
  10.     {
  11.         static void Main(string[] args)
  12.         {
  13.             long number = long.Parse(Console.ReadLine());
  14.             int freezePosition = int.Parse(Console.ReadLine());
  15.             int shiftRight = int.Parse(Console.ReadLine());
  16.  
  17.             //get frozen bit
  18.             long frozenBit = GetBit(number, freezePosition);
  19.  
  20.             //Console.WriteLine(Convert.ToString(number, 2).PadLeft(33,'0'));
  21.            
  22.             long rollNumber = number;
  23.             //for bits in between
  24.             if (freezePosition > 0 && freezePosition < 18)
  25.             {
  26.                 rollNumber = ExchangeBits(freezePosition, shiftRight, frozenBit, rollNumber);
  27.             }
  28.             else if ( freezePosition == 0)
  29.             {
  30.                 for (int i = 0; i < shiftRight; i++)
  31.                 {
  32.                     long bitA = GetBit(rollNumber, 1);
  33.                     rollNumber = rollNumber >> 1;
  34.                     rollNumber = SetBit(rollNumber, freezePosition, frozenBit);
  35.                     rollNumber = SetBit(rollNumber, 18, bitA);
  36.                 }
  37.             }
  38.             else if (freezePosition == 18)
  39.             {
  40.                 for (int i = 0; i < shiftRight; i++)
  41.                 {
  42.                     long bitA = GetBit(rollNumber, 0);
  43.                     rollNumber = rollNumber >> 1;
  44.                     rollNumber = SetBit(rollNumber, freezePosition, frozenBit);
  45.                     rollNumber = SetBit(rollNumber, 17, bitA);
  46.                 }
  47.             }
  48.  
  49.             //Console.WriteLine(Convert.ToString(rollNumber, 2).PadLeft(33,'0'));
  50.             Console.WriteLine(rollNumber);
  51.         }
  52.  
  53.         private static long ExchangeBits(int freezePosition, int shiftRight, long frozenBit, long rollNumber)
  54.         {
  55.             for (int i = 0; i < shiftRight; i++)
  56.             {
  57.                 long bitA = GetBit(rollNumber, 0);
  58.                 long beforeFrozenBit = GetBit(rollNumber, freezePosition + 1);
  59.                 rollNumber = rollNumber >> 1;
  60.                 rollNumber = SetBit(rollNumber, freezePosition, frozenBit);
  61.                 rollNumber = SetBit(rollNumber, freezePosition - 1, beforeFrozenBit);
  62.                 rollNumber = SetBit(rollNumber, 18, bitA);
  63.             }
  64.             return rollNumber;
  65.         }
  66.  
  67.  
  68.         public static long SetBit(long number, int position, long bitValue)
  69.         {
  70.             if (bitValue == 0)
  71.             {
  72.                 long mask = ~((long)1 << position);
  73.                 long result = number & mask;
  74.                 return result;
  75.             }
  76.             else if (bitValue == 1)
  77.             {
  78.                 long mask = (long)1 << position;
  79.                 long result = number | mask;
  80.                 return result;
  81.             }
  82.             else
  83.             {
  84.                 return 0;
  85.             }
  86.         }
  87.  
  88.         public static long GetBit(long number, int position)
  89.         {
  90.             long nRightP = number >> position;
  91.             long bit = nRightP & 1;
  92.  
  93.             return bit;
  94.         }      
  95.     }
  96. }
Advertisement
Add Comment
Please, Sign In to add comment