C语言学习记录
前言
一直自己没有学习做笔记的习惯,所以为了加强自己对知识的深入理解,决定将学习笔记写下来,希望向各位大牛们学习交流!
不当之处请斧正!在此感谢!这边就先从学习C语言写起,自己本身对程序语言方面不擅长,所以决定对此从基础开始学习,
大牛们对此文可以忽略!
学校OJ上的题目
母牛的故事
题目描述
有一头母牛,它每年年初生一头小母牛。每头小母牛从第四个年头开始,每年年初也生一头小母牛。请编程实现在第n年的时候,共有多少头母牛?
输入描述
输入数据由多个测试实例组成,每个测试实例占一行,包括一个整数n(0<n<55),n的含义如题目中描述。
n=0表示输入数据的结束,不做处理。
输出描述
对于每个测试实例,输出在第n年的时候母牛的数量。
每个输出占一行。
输入样例
2
4
5
0
输出样例
2
4
6
解题: 刚开始想的很复杂,各种算牛,整个人都不好了,什么数学统计法,归纳法,列出公式,都不好使,最后发现用递归就行了。
#include <stdio.h>
#include <stdlib.h>
int muniu(int valls);
int main(int argc, char *argv[]) {
int n,sum;
while(~scanf("%d",&n))
{
if(n==0) break;
/*(n*n-5*n+12)/2
n=(n*n-5*n+12)/2;*/
if(n>0 && n<55)
{
printf("%d\n",muniu(n));
}
}
return 0;
}
int muniu(int valls)
{
int m;
m=valls;
if(m<4)
{
return m;
}
else
{
m = muniu(valls-1)+muniu(valls-3);
return m;
}
}