C语言实现将任意一个整数转换成有限个fibonacci数之和

该博客介绍了如何使用C语言将任意整数拆解为有限个Fibonacci数的和,主要步骤包括生成最大数据范围内的Fibonacci数列并逆序遍历进行拆解。
摘要由CSDN通过智能技术生成

主要思路:
1.首先计算一个包含最大数据范围的fibonacci数表;
2.逆序循环遍历数表,对输入整数进行拆解。

/*--------------------------------------------------------------------
功能:将任意一个整数转换成几个fibonacci数之和
可以有多行输入,每行一个整数(本程序范围以10000以内为例),最后以0结束输入;
输入示例:
45
99
100
1000
10000
0
输出示例:
45 = 34 + 8 + 3
99 = 89 + 8 + 2
100 = 89 + 8 + 3
1000 = 987 + 13
10000 = 6765 + 2584 + 610 + 34 + 5 + 2
---------------------------------------------------------------------
Author:Zhang Kaizhou
Date: 2019-3-15 10:26:10
-------------------------------------------------------------------*/
#include <stdio.h>
#include <stdlib.h>
#define MAXSIZE 50
#define N 22

int fibonacci_table[MAXSIZE];

typedef struct node{ // 定义一个结点数据类型用于存放原始数据及最终结果
    int num;
    int res[MAXSIZE];
    int len;
    struct node * pnext;
} Node;

void init_fibonacci_table();
void compute_res
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值