Хранение массива значений по ключу - C#

Узнай цену своей работы

Формулировка задачи:

Стоит задача, проходясь по массиву, сохранить места расположения байтов. Например 63 - 2,15,29,54 и тд. То есть каждый раз когда вновь находим знакомый байт, добавляем в массив его расположение. Была мысль сделать через Dictioonary list'ов, так что б каждый байт был ключём.
Листинг программы
  1. static Dictionary<byte,List<int>> Statistic = new Dictionary<byte,List<int>>();
Но вроде как таким способом невозможно добавлять каждый раз число в лист. Как лучше всего это организовать?

Решение задачи: «Хранение массива значений по ключу»

textual
Листинг программы
  1. using System;
  2. using System.Linq;
  3. using System.Collections.Generic;
  4.  
  5. class Program
  6. {
  7.     public static void Main()
  8.     {
  9.         List<int>[] pos = new List<int>[256];
  10.         byte[] array = { 1, 2, 3, 4, 2, 2, 3 };
  11.         for (int i = 0; i < array.Length; ++i)
  12.         {
  13.             int b = array[i];
  14.             if (pos[b] == null) pos[b] = new List<int>();
  15.             pos[b].Add(i);
  16.         }
  17.         for (int i = 0; i < 256; ++i)
  18.         {
  19.             if (pos[i] != null) Console.WriteLine(String.Format("Byte {0} positions: {1}.", i, String.Join(", ", pos[i])));
  20.         }
  21.     }
  22. }

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

8   голосов , оценка 4.125 из 5

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут
Похожие ответы