鱼C论坛

 找回密码
 立即注册
查看: 2358|回复: 2

[已解决]定义函数

[复制链接]
发表于 2021-11-3 16:47:21 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
1:定义一个函数is(int num)用于判断num是否为水仙花数(各个数字的立方之和等于他本身)
在main中试用is函数输出m~n之间的所有水仙花数。
输入:整数m和n(m<n),空格隔开。输出:所有的水仙花数,每个数占一行
2:用递归函数打印出Fibonacci级数,公式:
F1=F2=1  (n=1,2)
Fn=Fn-1  +   Fn-2   (n>2)
输入=n。
输出:输出数据之间用空格隔开
最佳答案
2021-11-3 17:42:51
本帖最后由 jackz007 于 2021-11-3 17:45 编辑

【1】:
#include <stdio.h>

bool is(int n)
{
        int k , s                                                            ;
        for(s = 0 , k = n ; k ; k /= 10) s += (k % 10) * (k % 10) * (k % 10) ;
        return s == n                                                        ;
}

int main(void)
{
        int k , m , n                                                        ;
        scanf("%d%d" , & m , & n)                                            ;
        if(m > 99 && n < 1000 && n > m) {
                for(k = m ; k < n + 1 ; k ++) if(is(k)) printf("%d\n" , k)   ;
        } 
}
        编译、运行实况:
D:\0002.Exercise\C>g++ -o x x.c

D:\0002.Exercise\C>x
100 999
153
370
371
407

D:\0002.Exercise\C>
【2】:
#include <stdio.h>

int Fibonacci(int n)
{
        int r = 1                                       ;
        if(n > 2) {
                r = Fibonacci(n - 1) + Fibonacci(n - 2) ;
        }
        return r                                        ;
}

int main(void)
{
        int i , n                                                  ;
        scanf("%d" , & n)                                          ;
        printf("%d" , Fibonacci(1))                                ;
        for(i = 1 ; i < n ; i ++) printf(" %d" , Fibonacci(i + 1)) ;
        printf("\n")                                               ;
}
        编译、运行实况:
D:\0002.Exercise\C>g++ -o x x.c

D:\0002.Exercise\C>x
8
1 1 2 3 5 8 13 21

D:\0002.Exercise\C>
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-11-3 17:42:51 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2021-11-3 17:45 编辑

【1】:
#include <stdio.h>

bool is(int n)
{
        int k , s                                                            ;
        for(s = 0 , k = n ; k ; k /= 10) s += (k % 10) * (k % 10) * (k % 10) ;
        return s == n                                                        ;
}

int main(void)
{
        int k , m , n                                                        ;
        scanf("%d%d" , & m , & n)                                            ;
        if(m > 99 && n < 1000 && n > m) {
                for(k = m ; k < n + 1 ; k ++) if(is(k)) printf("%d\n" , k)   ;
        } 
}
        编译、运行实况:
D:\0002.Exercise\C>g++ -o x x.c

D:\0002.Exercise\C>x
100 999
153
370
371
407

D:\0002.Exercise\C>
【2】:
#include <stdio.h>

int Fibonacci(int n)
{
        int r = 1                                       ;
        if(n > 2) {
                r = Fibonacci(n - 1) + Fibonacci(n - 2) ;
        }
        return r                                        ;
}

int main(void)
{
        int i , n                                                  ;
        scanf("%d" , & n)                                          ;
        printf("%d" , Fibonacci(1))                                ;
        for(i = 1 ; i < n ; i ++) printf(" %d" , Fibonacci(i + 1)) ;
        printf("\n")                                               ;
}
        编译、运行实况:
D:\0002.Exercise\C>g++ -o x x.c

D:\0002.Exercise\C>x
8
1 1 2 3 5 8 13 21

D:\0002.Exercise\C>
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-11-3 18:07:42 | 显示全部楼层
混点经验升级
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-4 15:24

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表