有这么一道题目,要求用递归算法
我理解的递归算法是,要求的结果是和前面的结果有关系的,这种都可以用递归,难点是怎么挖掘出递归关系或者怎么想到用递归,这题已经告诉我们用递归算法了,所以难度就降低了。
思路如下:
容易得出an=10*a(n-1) +10;
因为n-1能取到的最小值是1,所以n必须大等于1
int f(int n) { if (n < 1) { printf("wrong iput "); return 0; } if (n ==1) { return 1; } return 10 * f(n - 1) + n; } int main() { int n = 0; int an = 0; scanf_s("%d",&n); an = f(n); printf("%d",an); }