Форум программистов, компьютерный форум, киберфорум
Алгоритмы
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
2 / 2 / 0
Регистрация: 12.10.2012
Сообщений: 17

Алгоритм разбивки массива

12.01.2013, 17:24. Показов 954. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
На досуге решил покурить тему алгоритмов. Наткнулся на одну задачу, которую никак не могу решить. Итак,

Есть массив из 25 байтов,

byte[] array = new byte[25];

который заполнен некоторой информацией.
Нужно предложить алгоритм, который разобьет этот массив на массив связанных блоков по 4 байта, то есть блок -

byte[] block = new byte[4];

и алгоритм, который соберет массив блоков обратно в массив байтов.

Свое видение, как оно должно быть я представил на рисунке (см. вложения), но вот сам алгоритм, что то никак не напишу. Помогите с задачкой, господа.
Миниатюры
Алгоритм разбивки массива  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.01.2013, 17:24
Ответы с готовыми решениями:

Алгоритм разбивки многоугольника с прямыми углами на прямоугольники
Всем привет. Все пытаюсь нагуглить информацию по теме, но кругом одна сплошная триангуляция. Мой задача проще - имеется многоугольник, у...

Алгоритм разбивки в дерево
Помогите с алгоритмом разбивки в дерево!

Алгоритм разбивки денег по счету
Ребята помогите с алгоритмом пожалуйста. Например есть ресторан в котором есть как товар так и услуга. Человек заказывает кофе, салатик...

3
1964 / 820 / 114
Регистрация: 01.10.2012
Сообщений: 4,782
Записей в блоге: 2
12.01.2013, 17:49
Все расписывать - долго и нудно. Вот структура данных, методы реализуете сами
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
struct CNode {
  CNode( const unsigned char * src, size_t num );
~CNode( void );
 
 void MakeChild( size_t numElem ); 
 void Merge1Child( void ); 
 void MergeChildren( void ); 
 
// data
 CNode * mChild;
 size_t mNumChild;
 
 unsigned char * mData;
 size_t mNumData;
};
Разбивка
C++
1
2
3
4
5
6
7
CNode * root = new CNode(src, 25);
root->MakeChild(16); 
root->MakeChild(4); 
root->MakeChild(4); 
root->MakeChild(1);
for (size_t i = 0; i < 4; ++i) 
 root->mChild[0]->MakeChild(4);
Слияние
C++
1
root->MergeChildren();
1
Модератор
10373 / 5660 / 3398
Регистрация: 17.08.2012
Сообщений: 17,298
12.01.2013, 21:36
А может, не нужен никакой алгоритм? Может, просто использовать ссылки, чтобы исходный массив возможно было использовать и так и сяк? Две различных переменных, занимающих одно и то же место в памяти? На макроассемблере такое издевательство над несколькими переменными называется common, на паскале то же самое можно сделать ссылками. На C не знаю как - я не очень программист.
0
1964 / 820 / 114
Регистрация: 01.10.2012
Сообщений: 4,782
Записей в блоге: 2
13.01.2013, 11:44
Цитата Сообщение от Cyborg Drone Посмотреть сообщение
А может, не нужен никакой алгоритм? Может, просто использовать ссылки, чтобы исходный массив возможно было использовать и так и сяк? Две различных переменных, занимающих одно и то же место в памяти? На макроассемблере такое издевательство над несколькими переменными называется common, на паскале то же самое можно сделать ссылками. На C не знаю как - я не очень программист.
C++
1
2
3
4
5
6
7
8
9
10
11
#pragma pack(push, 1)
union CMyData {
 unsigned char m1[25];
 struct m2 {
   unsigned char m2_1[4][4];
   unsigned char m2_2[4];
   unsigned char m2_3[4];
   unsigned char m2_4[1];
 }; 
};
#pragma pack(pop)
Но это фиксировано - мы не можем рахбивать произвольным образом в runtime
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.01.2013, 11:44
Помогаю со студенческими работами здесь

Ускорить алгоритм разбивки строк на блоки
Помогіте оптімізіровать алгорітм. Смысл такой.. есть строкі... в ніх сначала текст.. потом несколько чісел.. колічество чісел может...

Скрипт для разбивки файла
Привет всем.Появилась необходимость в скрипте,который будет нарезать файлы.Сам никогда этим не занимался (подскажите с чего начать и какой...

Просмотрщики разбивки адресного пространства
Народ, подскажите какую-нибудь утилитку, которая отображает как система разбивает всё адресное пространство и кому какие куски достаются.

Макрос разбивки текста в ячейке
Добрый день! Возникло непреодалимое желание разбить текст в 1 ячейке на несколько ячеек. Текс = Ip address. Кто-нибудь сможет...

Не загружается ПК после разбивки НЖМД Акронисом
Доброго времени суток!! Возникла проблема следующего рода. Имеется компьютерный класс. На рабочих местах установлена лицензионная Win...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru