c语言打卡

题目一 递归和非递归分别实现求第n个斐波那契数

  • 分析
    “兔子数列”,指的是这样一个数列:1、1、2、3、5、8、13、21、34
    通过数学归纳法 可以推出通项公式 F(1)=1,F(2)=1, F(3)=2,F(n)=F(n-1)+F(n-2)(n>=4,n∈N*)

  • 思路
    递归思想,将大问题化为小问题,当满足递归条件是就依次返回.
    在这里插入图片描述

    从这张图的中的文字 “吓得我抱起了 抱着 抱着 抱着 我的小鲤鱼 的我 的我 的我“
    我们可以知道 从(我抱起了)开始 —》(我的小鲤鱼结束) 就像一个调用过程,从(我的小鲤鱼)到最后一个字(我),就是一个返回过程,从我开始,也从我结束,这就是递归,有来有回。

  • 实现

void Fib(int n) {
   
	long long first = 1;
	long long second = 1;
	long long ret = 0;
	if (n == 1 || n == 2)
	{
   
		printf("斐波那契数是:%d", n);
	}
	else
	{
   
		for (int i = 3; i <= n; i++)
		{
   
			ret = first + second;
			first = second;
			second = ret;
		}
		printf("斐波那契数是:%d", ret);
	
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
统计某十五天内64 位员工的上班迟到早退的次数,星期天和星期六系统自动关闭;假设员工上下班都在标准点±1小时,不存在迟到或早退超过一小时的,其余时间系统自动关闭!迟到早退的次数记录在a.dat 日志分别记录在log_check_in和log_check_out里; 1.员工为我班同学,可比照代码中的结构体初始化的内容; 2.员工号为我班同学学号后3位数字,起始为067,在统计多日迟到累计次数过程有文件内容的修改操作和数据类型转换过程,为简化文件操作过程以及后面的查询过程,实际处理的是员工的序号,如员工号为073的记录为07; 3.签到有时间,如在周六周日不签,在系统关闭情况下,管理员可以进行相关维护操作,管理员密码123456; 4.签到过程记录了员工多日迟到早退的累计次数,更详细的内容写到log文件中,所有这些都可以查询; 5.程序为了更好的实现交互式查询的功能, 循环嵌套写得稍复杂 ; 6.觉得数据库的操作比文本文件的操作更有意义些,对员工信息的定义初始化直接在数组中完成;文件操作起来繁琐,没多大意义,所以打算待学会数据库初始化,数据库访问后再来完善; 7.尚未考虑如何精简程序,合理管理内存,待学会动态内存管理后再回头处理;8.感到不尽人意的是C的“不友好”,没有可视化的界面,没有面向对象语言的种种…… 康师傅 qq 1304622669 再缀:加了控台dos命令调用版缺点优点又都激增,想各程序爱好者给提多多建议,跪拜
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值