1.递归和非递归分别实现求第n个斐波那契数。
非递归实现:
#include<stdio.h>
#include<stdlib.h>
int Fib(n) {
if (n <= 1) {
return 1;
}
int last1 = 1;
int last2 = 1;
int i = 3;
int cur = 0;
for (i = 3;i <= n;i++) {
cur = last1 + last2;
last2 = last1;
last1 = cur;
}
return cur;
}
int main() {
int n;
printf("请输入数字:\n");
scanf_s("%d", &n);
printf("%d\n", Fib(n));
system("pause");
return 0;
}
递归实现:
#include<stdio.h>
#include<stdlib.h>
int Fib(int n) {
if (n == 1) {
return 1;
}
if (n == 2) {
return 1;
}
return Fib(n - 1) + Fib(n - 2);
}
int main() {
int k = 0;
printf("求第几个数:");
scanf_s("%d", &k);
int ret = Fib(k);
printf("%d\n", ret);
system("pause");
return 0;
}
2.编写一个函数实现n^k,使用递归实现 。
#include<stdio.h>
#include<windows.h>
int fact(int n, int k) {
if (k == 1) {
return n;
}
return n * fact(n, k - 1);
}
int main() {
int n = 0;
int k = 0;
int s = 0;
printf("求n^k的值:\n");
printf("请输入n的值:\n");
scanf_s("%d", &n);
printf("请输入k的值:\n");
scanf_s("%d", &k);
s = fact(n, k);
printf("%d\n", s);
return 0;
}
- 写一个递归函数DigitSum(n),输入一个非负整数,返回组成它的数字之和。例如,调用DigitSum(1729),则应该返回1+7+2+9,它的和是19 。
#include<stdio.h>
#include<stdlib.h>
int DigtSum(int n) {
int j = 0;
int sum = 0;
if (n != 0) {
j = n % 10;
n = n / 10;
sum = j + DigtSum(n);
}
return sum;
}
int main() {
int ret, a;
printf("请输入数字:\n");
scanf_s("%d", &a);
ret = DigtSum(a);
printf("%d", ret);
return 0;
}
- 编写一个函数 reverse_string(char * string)(递归实现实现:将参数字符串中的字符反向排列。 要求:不能使用C函数库中的字符串操作函数。
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
void reverse_string(char *string) {
if (*string == '\0')
return 0;
reverse_string(string + 1);
printf("%c", *string);
}
int main() {
char* str = "sdasd";
reverse_string(str);
return 0;
}
5.递归和非递归分别实现strlen 。
递归实现:
#include<stdio.h>
char strlen(char* n ){
if (*n == '\0')
return 0;
return 1 + strlen(n + 1);
}
int main() {
char n[] = "sadas";
int ret = strlen(n);
printf("%d", ret);
return 0;
}
非递归实现:
#include<stdio.h>
int strlen(char* string) {
int count = 0;
while (*string != '\0') {
count++;
string++;
}
return count;
}
int main() {
char* string = "dsafasd";
printf("%d", strlen(string));
}
6.递归和非递归分别实现求n的阶乘 。
非递归实现:
#include<stdio.h>
int main() {
int i, sum = 1, n = 0;
printf("请输入n的值:\n");
scanf_s("%d", &n);
for (i = 1;i <= n;i++) {
sum *= i;
}
printf("%d", sum);
}
递归实现:
#include<stdio.h>
int jc(int n) {
int sum = 1;
if (n == 1) {
return 1;
}
return n * jc(n - 1);
}
int main() {
int n;
printf("请输入n:\n");
scanf_s("%d", &n);
printf("%d", jc(n));
return 0;
}
7.递归方式实现打印一个整数的每一位 。
#include<stdio.h>
int pict(int n) {
if (n > 9) {
pict(n / 10);
}
printf("%d\n", n % 10);
return 1;
}
int main() {
int n;
printf("请输入一个数:\n");
scanf_s("%d", &n);
pict(n);
}