Форум программистов, компьютерный форум, киберфорум
Алгоритмы
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/18: Рейтинг темы: голосов - 18, средняя оценка - 5.00
1552 / 918 / 193
Регистрация: 26.03.2010
Сообщений: 3,105

Сжатие последовательности

16.12.2010, 18:44. Показов 3781. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
вечер добрый. ребят, помогите с алгоритмом кто-нибудь.

Сжатие последовательности.
В этой задаче вам предстоит заняться сжатием данных. Правда, метод сжатия, который предстоит изучить, предназначен только для сжатия последовательностей из N единиц. Метод сжатия основывается на представлении последовательности из N единиц в виде последовательности из чисел, каждое из которых лежит в диапозоне от 1 до A, так, чтобы суммы членов обоих последовательностей совпадали (т.е. были равны N). Ваша задача - посчитать кол-во способов сжать заданную последовательность.

Входные данные: N и A
Выходные данные : одно число - ответ.

Пример: N=4, A=2
Возможные варианты:
1111
112
121
211
22

пытался решить с помощью динамики - не получилось. вроде как написал - но не учел один момент и программа считала не все варианты, а там и олимпиада закончилась сейчас просто интерестно, какого же решение. спасибо.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.12.2010, 18:44
Ответы с готовыми решениями:

Арифметическое кодирование/сжатие
Здравствуйте! С помощью арифметического сжатия/кодирования требуется закодировать сообщение "информационный", а затем...

Алгоритм jpeg (сжатие)
Здравствуйте, разбираюсь с алгоритмом сжатия изображений (JPEG) Вот по этой статье http://www.codenet.ru/progr/alg/jpeg_00.php ...

сжатие бинарного файла
Подскажите метод,который наиболее подходил бы по сжатию бинарного файла...заранее спасибо)))

6
15 / 15 / 1
Регистрация: 23.10.2010
Сообщений: 83
16.12.2010, 20:31
сколько баллов начисляли за это задание?... может быть там точно решение не влоб) такое бывает в наши дни одна формула и все вычисления как на ладони)
0
1552 / 918 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
16.12.2010, 20:48  [ТС]
Там помоему за каждую задачу максимум 100 баллов.
Система проверяет, и по кол-ву пройденных тестов уже определяется конечный балл за задачу.

Возможно)
0
Эксперт С++
 Аватар для Mr.X
3225 / 1752 / 436
Регистрация: 03.05.2010
Сообщений: 3,867
16.12.2010, 21:49
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
//////////////////////////////////////////////////////////////////////////////////////
#include <iostream>
//////////////////////////////////////////////////////////////////////////////////////
long long  solution_counter = 0;
//////////////////////////////////////////////////////////////////////////////////////
void  summands_partition
    (
        int  n_start,
        int  n_cur,
        int  summand_max        
    )
{
    if(!n_cur)  
    {
        ++solution_counter;
        return;
    }    
    
    for(int cur_slag = 1; 
        cur_slag <= summand_max && n_cur - cur_slag >= 0; ++cur_slag)    
    {
        summands_partition(n_start, n_cur - cur_slag, summand_max);
    }
}
//////////////////////////////////////////////////////////////////////////////////////
int main()
{
    std::cout << "N = ";
    int  N = 0;
    std::cin >> N;
 
    std::cout << "A = ";
    int  A = 0;
    std::cin >> A;
 
    summands_partition(N, N, A);
    std::cout << std::endl
              << solution_counter - 1
              << std::endl;
}
1
1552 / 918 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
16.12.2010, 22:32  [ТС]
Mr.X, спасибо за решение, но можешь озвучить сам алгоритм?

Добавлено через 5 минут
А, все. Если я верно понял, то это перебор с возвратом.
Я пытался как-то с массивами, в общем понятно, спасибо
0
Эксперт С++
 Аватар для Хохол
476 / 444 / 34
Регистрация: 20.11.2009
Сообщений: 1,293
17.12.2010, 01:51
Это очень простая динамика.
Найти количество способов разбиения N на слагаемые не большие A, причем суммы, различающиеся лишь порядком считаются различными.
Пусть dp[i] - ответ для N = i.
Очевидно, dp[0] = 1.
dp[i] = dp[i-A] + dp[i-A+1] + ... dp[i-1].
Итого O(A*N).
Вот попрактикуйтесь:
http://acmp.ru/index.asp?main=task&id_task=11
1
1552 / 918 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
17.12.2010, 19:01  [ТС]
Большое спасибо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
17.12.2010, 19:01
Помогаю со студенческими работами здесь

Сжатие текстовых данных
Есть текст, необходимо его сжать. Подскажите алгоритм дающий хорошие результаты, по которому есть туториал.

Сжатие файлов в ZIP архивы.
Поскажите, пожалуста, где можно найти удобную библиотеку для сжатия файлов в zip-архив. Нужно, чтобы библиотеку можно было легко перенести...

Вопросы про сжатие файлов
1. Патент на арифметическое кодирование просрочен? Если нет, то почему о нем массово пишут? О RAR же не пишут? 2. Известно, что...

Jpeg сжатие. Стандартные таблицы Хаффмана
Доброго дня! Пытаюсь разобраться с алгоритмом сжатия Jpeg. Завис на этапе кодирования Хаффмана. Как я понял на этом этапе чаще всего...

Сжатие изображений посредством фрактальной геометрии
Здравствуйте! Подскажите, пожалуйста, книги по сжатию изображений с помощью фрактальной геометрии. Я читал С. Уэлстида «Фракталы и...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru