Перечислить все разбиения натурального числа на натуральные слагаемые - C (СИ)

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

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

у меня есть код, но он работает неправильно. Я так понимаю, что где-то надо сделать рекурсию, помогите пожалуйста, разобраться.
Листинг программы
  1. #include <stdio.h>
  2. int main() {
  3. int i, n, k, sum, s;
  4. int x[1000];
  5. scanf("%d", &n);
  6. for (i = 0; i < n; i++) {
  7. x[i] = 1;
  8. }
  9. k = n;
  10. s = k - 1;
  11. while((x[s] ==1)||(x[s-1]>x[s])) {
  12. s = s-1;
  13. x[s] = x[s] + 1;
  14. sum = 0;
  15. }
  16. for (i=s+1; i<k; i++) {
  17. sum = sum + x[i];
  18. }
  19. for (i=1; i<sum-1; i++) {
  20. x[s+1]= 1;
  21. }
  22. k= s+sum-1;
  23.  
  24. for (i=1; i<n; i++){
  25. printf("%d", x[i]);
  26. }
  27. return 0;
  28. }

Решение задачи: «Перечислить все разбиения натурального числа на натуральные слагаемые»

textual
Листинг программы
  1. void find(unsigned int k, unsigned int m, char *p, char *ps)
  2. {
  3.     sprintf(p, "%d\n", k); printf(ps);
  4.     for (unsigned int i=m; i<=k/2; i++) find(k-i, i, p+sprintf(p, "%d+", i), ps);
  5. }
  6. int _tmain(int argc, _TCHAR* argv[])
  7. {
  8.     char r[100];
  9.     find(15, 1, r, r);
  10.     system("pause");
  11.     return 0;
  12. }

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


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

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

13   голосов , оценка 3.923 из 5

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

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

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