当前位置: 首页 > news >正文

K阶斐波那契数列(数据结构)

代码:

注意k阶斐波那契序列定义:第k和k+1项为1,前k - 1项为0,从k项之后每一项都是前k项的和

例如:k=2时,斐波那契序列为:0,1,1,2,3,5,8,13...

k=3时,斐波那契序列为:0,0,1,1,2,4,7,13,24...

#include <stdio.h>
#include <stdlib.h>typedef struct  Queue
{int data[100];//数据int front;//头指示器int rear;//尾指示器
} SeqQueue;void Initqueue(SeqQueue*Q);//初始化循环队列
void Compute(int max,int k,SeqQueue*Q);//计算斐波那契数列
void Printfqueue(SeqQueue*Q,int k);//输出最后k项int main()
{SeqQueue queue;int Max,K;Initqueue(&queue);//初始化循环队列scanf("%d %d",&Max,&K);//输入约定的常数与阶数Compute(Max,K,&queue);//计算斐波那契数列Printfqueue(&queue,K);//输出最后k项return 0;
}/*初始化循环队列*Q:被初始化的队*/
void Initqueue(SeqQueue*Q)
{Q->front=Q->rear=0;
}/*计算斐波那契数列  f(0)到f(n);*max: f(n)<=max,f(n+1)>max*k: 要求输出的最后 k 项*Q:目标循环队列*/
void Compute(int max,int k,SeqQueue*Q)
{int sum1=0,sum2=1;//此时sum1是前k-1个数的和,sum2是前k个数和Q->rear=k-1;for(int i=0; i<k-1; i++){Q->data[i]=0;//前k-1个数置为0}Q->data[k-1]=1;//第k个数为1while(!(sum2>max&&sum1<=max))//sum1是f(n),sum2是f(n+1){int t=Q->data[Q->front],m,n;sum1=sum2;//下一个sum1等于sum2n=Q->rear=(Q->rear+1)%k;//形成只有k个数据的循环队列Q->data[Q->rear]=sum1;//入栈的是前k个数之和sum2=sum2-t+sum1;//下一个sum2 = 原来的sum2 - 队头:t + 新增的队尾:sum1m=Q->front=(Q->front+1)%k;//队头后移}
}/*输出最后k项*Q:目标队列*k:要求的项数*/
void Printfqueue(SeqQueue*Q,int k)
{for(int i=Q->front; i!=Q->rear; i++){i=i%k;printf("%d ",Q->data[i]);}printf("%d",Q->data[Q->rear]);//特殊处理
}

http://www.lryc.cn/news/104866.html

相关文章:

  • 【JavaEE】博客系统前后端交互
  • Redis 简介
  • CS162 13-17 虚拟内存
  • 接口自动化测试-Jmeter+ant+jenkins实战持续集成(详细)
  • 最长连续序列——力扣128
  • uniapp app端 echarts 设置tooltip的formatter不生效问题以及解决办法
  • Spring入门-技术简介、IOC技术、Bean、DI
  • 深度学习之反向传播
  • 网络安全 Day23-mariadb数据库数据管理和备份
  • Centos7 上安装 redis-dump 和redis-load 命令
  • 【NLP PyTorch】字符级RNN循环网络模型姓氏对应国家分类(项目详解)
  • C++设计模式之责任链设计模式
  • 《Java-SE-第二十三章》之单例模式
  • 如何快速同步第三方平台数据?
  • 反射(一)
  • 29.利用fminbnd 求解 最大容积问题(matlab程序)
  • express学习笔记7 - docker跟mysql篇
  • Leetcode(一):数组、链表部分经典题目详解(JavaScript版)
  • 内网穿透的底层原理是什么
  • Bash配置文件
  • 写Acknowledgement的时候,latex日志出现警告
  • GCC生成map文件
  • IOS看书最终选择|源阅读转换|开源阅读|IOS自签
  • easyui实用点
  • 算法训练营第五十六天||● 583. 两个字符串的删除操作 ● 72. 编辑距离 ● 编辑距离总结篇
  • C语言每日一题:10.不使用+-*/实现加法+找到所有数组中消失的数。
  • LibreSSL SSL_connect: SSL_ERROR_SYSCALL in connection to github.com:443
  • JS数组的详解与使用
  • c++ / python / java / PHP / SQL / Ruby / Objective-C / JavaScript 发展史
  • Linux第一个小程序-进度条(缓冲区概念)