С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/55: Рейтинг темы: голосов - 55, средняя оценка - 4.89
0 / 0 / 0
Регистрация: 26.12.2013
Сообщений: 3
1

Подсчитать количество различных разбиений числа N на натуральные слагаемые

23.06.2014, 19:57. Показов 10187. Ответов 4
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Условие: требуется подсчитать количество различных разбиений числа N на натуральные слагаемые. Два разложения считаются различными, если одно нельзя получить из другого путем перестановки слагаемых.

Имеется вот такой код, но нужно найти в нём ошибку.

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
#include "stdio.h"
#include "stdafx.h"
#include <iostream>
#include <cstring>
 
using namespace std;
 
int F(int **array, int n, int k, int i){
    int s;
    if (array[n][k] < 0){
        array[n][k] = 0;
        for (i = 0; i < k; i++) array[n][k] += F(array, n - k, k, i);
    }
    return array[n][k];
}
 
int main(){
    int i, j, k, n, m, sum;
    cout << "n = "; cin >> n;
    cout << "m = "; cin >> m;
    int **array = new int *[m];
    memset(array, sizeof(array), 0);
    for (i = 0; i < n; i++){
        array[i][i] = 1;
        array[i][1] = 1;
    }
    for (i = 1; i < n; i++)
    for (j = 1; j < (i - 1); j++)
        array[i][j] = -1;
    sum = 0;
    for (i = 0; i < n; i++)
        sum = sum + F(array, n, i, i);
    cout << "sum = " << sum;
    return 0;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
23.06.2014, 19:57
Ответы с готовыми решениями:

Количество разбиений числа на нечетные слагаемые
Нужно найти число способов ризбивки числа в виде суммы положительных целых нечетных чисел. ва...

Подсчитайте количество различных разбиений числа n на суммы натуральных слагаемых
Помогите пожалуйста решить задачку

Для числа от 2 до 20 распечатайте количество его различных разбиений на сумму натуральных слагаемых
Для данного натурального числа от 2 до 20 распечатайте количество его раз-личных разбиений на сумму...

Распечатать количество различных разбиений числа на сумму натуральных слагаемых, используя рекурсию
Для данного натурального числа от 2 до 20 распечатайте количество его различных разбиений на сумму...

4
Заблокирован
23.06.2014, 20:06 2
Массив как структура не подходит для решения этого задания: вы же не знаете ни количества сумм, ни количества слагаемых в каждой сумме. Если хотите запоминать, нужен стек (пусть даже и на массиве).

Кстати, можно ничего не запоминать. Просто выводить суммы и подсчитывать их количество.
0
413 / 250 / 118
Регистрация: 26.12.2012
Сообщений: 787
23.06.2014, 21:33 3
Посмотрите здесь
Показать все возможные комбинации чисел составляющих сумму заданного числа
Возможно вам поможет.
0
221 / 166 / 47
Регистрация: 17.07.2012
Сообщений: 587
24.06.2014, 02:50 4
C++ (Qt)
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
#include <iostream>
#include <algorithm>
#include <string>
#include <vector>
 
using namespace std;
 
typedef long long li;
 
li dp[1111][1111];
 
int main()
{
    int n;
    cin >> n;
    for(int i = 1; i <= n; i++)
        dp[i][i] = 1;
 
    for(int i = 1; i < n; i++)
        for(int j = 1; j < n; j++)
        {
            for(int k = j; k <= n; k++)
            {
                int ni = i + k;
                if(ni <= n)
                    dp[ni][k] += dp[i][j];
            }
        }
 
    li ans = 0;
    for(int i = 1; i <= n; i++)
        ans += dp[n][i];
 
    cout << ans << endl;
    return 0;
}
Добавлено через 1 минуту
погоди! тебе надо разбить число ровно на M слагаемых? мой код учитывает разбиения любой длины.
0
0 / 0 / 0
Регистрация: 26.12.2013
Сообщений: 3
24.06.2014, 10:45  [ТС] 5
Спасибо всем за ответы. Здесь суть моей задачи даже не столько в разбиениях, а сколько в том, что мне нужно запоминать значения, да.
0
24.06.2014, 10:45
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
24.06.2014, 10:45
Помогаю со студенческими работами здесь

В массиве выделить натуральные числа и подсчитать их количество
В массиве из N действительных чисел(N&lt;=10 и числа вводятся с клавиатуры)выделить натуральные числа...

Перечислить все разбиения натурального числа на натуральные слагаемые
у меня есть код, но он работает неправильно. Я так понимаю, что где-то надо сделать рекурсию,...

Число разбиений на слагаемые C++
Подскажите, есть такая задача. По данному целому числу 1≤n≤1000 найдите число способов...

Число разбиений на нечетные слагаемые
Нужно найти число способов ризбивки числа в виде суммы положительных целых нечетных чисел. ва...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru