|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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。
输出:输出数据之间用空格隔开
本帖最后由 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>
复制代码
|
|