为什么此递归求和函数无法正常工作?

问题描述

CS50课程中存在此Mario问题,使用递归方法很容易,除了当我尝试添加任何算术运算时,它都会显示(无效的操作数到二进制表达式中(“ void”和“ int” ))。只是为了我自己,我了解使用递归可以做什么和不能做什么;问题是这一行(sum(n-1)+n;

代码如下:

#include <cs50.h>
#include <stdio.h>

void sum(int n);

int main ()
{
    int u = get_int("f");
    sum (u);
}

void sum(int n)
{
  if (n==0)
  {
    return;
  }
  sum(n-1)+n;
  for(int i = 0 ; i < n; i++)
  {
    printf( "#");
  }
  printf("\n");
}

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)