C语言初学练习(六)

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;
}

运行结果如下
在这里插入图片描述

  1. 写一个递归函数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;
}

运行结果如下
在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值