1.第n个斐波那契数。
递归实现
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
int fibonacci(int n) {
if (n <= 2) {
return 1;
}
else {
return fibonacci(n - 1) + fibonacci(n - 2);
}
}
int main() {
int n;
printf("请输入要求的斐波那契数的位数:\n");
scanf("%d", &n);
int ret = fibonacci(n);
printf("%d", ret);
system("pause");
return 0;
}
运行结果如下
非递归实现
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
int main() {
int n;
printf("请输入要求的斐波那契数的位数:\n");
scanf("%d", &n);
int a = 1;
int b = 1;
int c = 0;
while (n > 2) {
c = a + b;
a = b;
b = c;
n--;
}
printf("%d\n", c);
system("pause");
return 0;
}
2.编写一个函数实现n^k,使用递归实现
代码如下
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int Mypow(int n, int k)
{
if (k == 0)
{
return 1;
}
else if (k == 1)
{
return n;
}
else
{
return n * Mypow(n, k - 1);
}
}
int main()
{
int n = 2;
int k = 5;
int c = Mypow(n, k);
printf("%d^%d = %d\n", n, k, c);
return 0;
}
运行结果如下
- 写一个递归函数DigitSum(n),输入一个非负整数,返回组成它的数字之和,
例如,调用DigitSum(1729),则应该返回1+7+2+9,它的和是19
代码如下
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int DigitSum(int n) {
if (n < 10) {
return n;
}
return (n % 10) + DigitSum(n / 10);
}
int main() {
int n = 0;
printf("请输入一个正整数:\n");
scanf("%d", &n);
printf("%d\n", DigitSum(n));
system("pause");
return 0;
}
运行结果如下
4. 编写一个函数 reverse_string(char * string)(递归实现)
实现:将参数字符串中的字符反向排列。
要求:不能使用C函数库中的字符串操作函数。
代码如下
#include <stdio.h>
char* reverse_string(char* p) {
int n = 0;
char temp;
char* q;
q = p;
while (*p != 0)
{
n++;
p++;
}
if (n > 1)
{
temp = q[0];
q[0] = q[n - 1];
q[n - 1] = '\0';
reverse_string(q + 1);
q[n - 1] = temp;
}
return q;
}
int main()
{
char p[] = "glandty";
printf("原字符串是:%s\n", p);
printf("翻转后的字符串是:%s\n", reverse_string(p));
return 0;
}
运行结果如下
5.递归和非递归分别实现strlen
递归实现
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
int my_strlen(const char* str)
{
assert(str != NULL);
if (*str == '\0')
return 0;
else
return 1 + my_strlen(str + 1);
}
int main()
{
char string[1024] = "ajaifsj";
printf("%d\n", my_strlen(string));
system("pause");
return 0;
}
运行结果如下
非递归实现
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
int my_strlen(const char* str)
{
assert(str != NULL);
int count = 0;
while (*str != '\0')
{
count++;
str++;
}
return count;
}
int main()
{
char string[] = { "abcdef" };
printf("%d", my_strlen(string));
printf("%d", my_strlen(string));
system("pause");
return 0;
}
运行结果如下
6.递归和非递归分别实现求n的阶乘
递归实现
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int Find_num(int num)
{
if (num == 0)
{
return 0;
}
else if (num == 1)
{
return 1;
}
else
{
return num * Find_num(num - 1);
}
}
int main()
{
int num = 1;
printf("请输入数字:\n");
scanf("%d", &num);
int find_num = Find_num(num);
printf("%d", find_num);
return 0;
}
运行结果如下
非递归实现
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int main()
{
int num = 1;
printf("请输入数字:\n");
scanf("%d", &num);
int n = num - 1;
while (n > 0)
{
num = num * n;
--n;
}
printf("%d", num);
return 0;
}
运行结果如下
7.递归方式实现打印一个整数的每一位
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
void Find_num(int num)
{
if (num < 10)
{
printf("%d\n", num);
}
else
{
Find_num(num / 10);
printf("%d\n", num % 10);
}
}
int main()
{
int num = 0;
printf("请输入数字:\n");
scanf("%d", &num);
Find_num(num);
return 0;
}
运行结果如下