Премини към съдържанието
Форумът в приложение

По-лесно сърфиране. Научи повече.

Kaldata.com - Форуми

Приложение на форума на цял екран с push известия, значки и други.

За да инсталирате това приложение на iOS и iPadOS
  1. Докоснете Иконата за споделяне в Safari
  2. Превъртете менюто и докоснете Добавяне към началния екран.
  3. Докоснете Добавяне в горния десен ъгъл.
За да инсталирате това приложение на Android
  1. Докоснете менюто с 3 точки (⋮) в горния десен ъгъл на браузъра.
  2. Докоснете Добавяне към началния екран или Инсталиране на приложение.
  3. Потвърдете, като докоснете Инсталиране.

Добре дошли!

Добре дошли в нашите форуми, пълни с полезна информация. Имате проблем с компютъра или телефона си? Публикувайте нова тема и ще намерите решение на всичките си проблеми. Общувайте свободно и открийте безброй нови приятели.

Моля, регистрирайте се за да публикувате тема и да получите пълен достъп до всички функции.

 

Рекурсия- разбиване на числа

Featured Replies

Здравейте! Трябва да реша една задача с рекурсия, която да разбива естествени числа, но не ми е ясно как ще стане. На теория знам какво трябва да се направи, но кодирано ми е трудно да я осъществя. Задачата трябва да е написана на c++ ,а ето я и нея: Разбиване на естествено число N наричаме последователност от естествени числа, чиято сума е N.  Да се състави програма, която реализира разбиването на дадено естествено число N.  Написвам от клавиатурата числото 4(примерно), това число трябва да се разбие на всички възможни събираеми. 1+1+1+1, 2+1+1, 3+1 4+0. Ако някой има идея за сорс код, моля да сподели. Благодаря!

Числата би трябвало да са 1+1+1+1, 2+1+1, 2+2 и 3+1  но не и 4+0 .  Имаше преди време такава тема ама не ми се търси.

Редактирано от ined (преглед на промените)

#include <iostream>

using namespace std;

int *s;
void out(int x, int step,int pos)
{
     if (x==0) 
     {
          --pos;
          for(int i=0; i<pos;++i)
              cout<<s[i]<<"+";
          cout<<s[pos]<<endl;
          return;
     }
     for (int i=step; i>0; --i)
     {
         if (x>=i) 
         {
             s[pos]=i;   
             out(x-i,i,pos+1);
         }
     }
}

int main()
{
    int n;
    while(1) 
    {
        cout<<"n = ";
        cin>>n;
        if (n<1) break;
        s=new int[n];
        out(n,n-1,0);
        delete[] s;
    }
}

 

Редактирано от ined (преглед на промените)

  • Автор
преди 2 часа, ined написа:

#include <iostream>

using namespace std;

int *s;
void out(int x, int step,int pos)
{
     if (x==0) 
     {
          --pos;
          for(int i=0; i<pos;++i)
              cout<<s[i]<<"+";
          cout<<s[pos]<<endl;
          return;
     }
     for (int i=step; i>0; --i)
     {
         if (x>=i) 
         {
             s[pos]=i;   
             out(x-i,i,pos+1);
         }
     }
}

int main()
{
    int n;
    while(1) 
    {
        cout<<"n = ";
        cin>>n;
        if (n<1) break;
        s=new int[n];
        out(n,n-1,0);
        delete[] s;
    }
}

 

Благодаря ти!!

#include <iostream>
#include <vector>
using namespace std;

vector <vector <vector <int>>> common_cup =
{ { {} }, { {} }, { { 2 }, { 1, 1 } } };      // общия кюп


void findsums(int n)
{
	int i, j;
	int diff;
	if ((common_cup.size() == n + 1)) return;
	findsums(n - 1);
	common_cup.push_back({ { n } });
	for (i = n - 1; i >= n / 2 + n % 2; i--)
	{
		diff = n - i;
		for (j = 0; j < common_cup[i].size(); j++)
		{
			if (common_cup[i][j][0] < diff) continue;
			common_cup[n].push_back(common_cup[i][j]);
			common_cup[n][common_cup[n].size() - 1]
				.insert(common_cup[n][common_cup[n].size() - 1].begin()
				, diff);
		}
	}
}

int main()
{
	int i, j;
	int n;
	cout << "n = ";
	cin >> n;
  	if (n < 2)
	{
		cout << "No solution.";
		return 0;
	}
	findsums(n);
	for (i = 1; i < common_cup[n].size(); i++)
	{
		for (j = 0; j < common_cup[n][i].size(); j++)
		{
			cout << common_cup[n][i][j] << " ";
		}
		cout << endl;
	}
	return 0;
}

 

Редактирано от Реджеп Иведик (преглед на промените)

Архивирана тема

Темата е твърде стара и е архивирана. Не можете да добавяте нови отговори в нея, но винаги можете да публикувате нова тема, в която да продължи дискусията. Регистрирайте се или влезте във вашия профил за да публикувате нова тема.

Разглеждащи това в момента 0

  • Няма регистрирани потребители разглеждащи тази страница.

Дарение

  • Подкрепи съществуването на форума - направи дарение
    25%
    Дарени 252.69 EUR от нужните 1,000.00 EUR

Бюлетин

Получавайте известие, когато има важна промяна или новина свързана с форума.

Профил

Навигация

Търсене

Търсене

Конфигуриране на push известия в браузъра

Chrome (Android)
  1. Докоснете иконата на катинар до адресната лента.
  2. Докоснете Разрешения → Известия.
  3. Променете предпочитанията си.
Chrome (Desktop)
  1. Кликнете върху иконата на катинар в адресната лента.
  2. Изберете Настройки на сайта.
  3. Намерете Известия и коригирайте предпочитанията си.