예제 #1
0
        static string Encode(string nums)
        {
            List <Bnum> n = new List <Bnum>();   //массив двоичных чисел

            for (int i = 0; i < nums.Length; i++)
            {
                //if (bittemp == i + 1)
                //{
                //    n.Add(new Bnum(0));
                //    bittemp *= 2;
                //    kbcount++;
                //    continue;
                //}
                n.Add(new Bnum(int.Parse(nums.Substring(i, 1))));
            }
            int bittemp = 1;
            int kbcount = 0;

            for (int i = 0; i < n.Count; i++)   //вставляем к.биты
            {
                if (i == bittemp - 1)
                {
                    n.Insert(i, new Bnum(0));
                    bittemp *= 2;
                    kbcount++;
                }
            }
            bittemp = 1;
            for (int i = 0; i < kbcount; i++)   //для каждого к.б.
            {
                Bnum sum  = new Bnum(0);
                int  step = bittemp;
                bool skip = false;
                for (int j = bittemp - 1; j < n.Count; j++)  // вычисляем значение
                {
                    if (step == 0)
                    {
                        step = bittemp;
                        skip = !skip;
                    }
                    if (skip)
                    {
                        step--;
                        continue;
                    }
                    else
                    {
                        sum = sum + n[j];
                        step--;
                    }
                }
                n[bittemp - 1] = sum;
                bittemp       *= 2;
            }

            string temp = "";

            foreach (var i in n)
            {
                temp += i.ToString();
            }
            return(temp);
        }
예제 #2
0
        static string Decode(string nums)
        {
            List <Bnum> n = new List <Bnum>();

            for (int i = 0; i < nums.Length; i++)
            {
                n.Add(new Bnum(int.Parse(nums.Substring(i, 1))));
            }
            int kbcount = 0; int bittemp = 1;

            while (bittemp < n.Count)
            {
                bittemp *= 2; kbcount++;
            }

            bittemp = 1;
            List <int> ind = new List <int>(); // массив несовпадающих битов

            for (int i = 0; i < kbcount; i++)
            {
                Bnum sum  = new Bnum(0);
                int  step = bittemp;
                bool skip = false;
                for (int j = bittemp - 1; j < n.Count; j++)
                {
                    if (step == 0)
                    {
                        step = bittemp;
                        skip = !skip;
                    }
                    if (skip)
                    {
                        step--;
                        continue;
                    }
                    else
                    {
                        sum = sum + n[j];
                        step--;
                    }
                }
                if (0 != sum)
                {
                    ind.Add(bittemp);              //запоминаем несовпадающие биты
                }
                bittemp *= 2;
            }
            if (ind.Count != 0)
            {
                int wrongbit = 0;
                foreach (var i in ind)
                {
                    wrongbit += i;
                }
                wrongbit--;                 //превращаем в индекс
                if (n[wrongbit] == 0)
                {
                    n[wrongbit] = new Bnum(1);
                }
                else
                {
                    n[wrongbit] = new Bnum(0);
                }
            }
            bittemp = (int)Math.Pow(2, kbcount - 1);
            for (int i = 0; i < kbcount; i++)
            {
                n.RemoveAt(bittemp - 1);
                bittemp /= 2;
            }

            string temp = "";

            foreach (var i in n)
            {
                temp += i.ToString();
            }
            return(temp);
        }