27.判断val是否为素数,并将1到val之间的素数全部输出来
# include<stdio.h>
int main(void)
{
int val;
int i;
int j;
scanf("%d",&val);
for (i = 2; i <= val; i++)
{
for (j = 2; j < i; j++)
{
if (0 == i%j)
break;
}
if (j == i)
printf ("%d\n",i);
}
return 0;
}
/*
//实际工作中应该写下面的代码,可移植性、重用性高
# include<stdio.h>
bool IsPrime(int m) //函数1 :判断m是否为素数, 是true不是false
{
int i;
for (i = 2; i < m; i++)
{
if (0 == m%i)
break;
}
if (i == m)
return true;
else
return false;
}
void TraverseVal(int n) //函数2:把1到n之间的素数输出
{
int i;
for (i = 2; i <= n; i++)
{
if (IsPrime(i))
printf ("%d\n",i);
}
}
int main(void)
{
int val;
scanf("%d",&val);
TraverseVal(val);
return 0;
}
28.小母牛生小牛问题
//设有一头小母牛,从出生第四年起每年生一头小母牛,按此规律,第N年时有几头母牛?
# include<stdio.h>
int main (void)
{
int i, N, S;
a = 1;
b = 0;
c = 0;
d = 0;
scanf ("%d",&N);
for (i = 1; i < N; i++)
{
d = d + c;
c = b;
b = a;
a = d;
}
S = a + b + c + d;
printf ("%d",S);
return 0;
}
//还可以用递归法做:S(N) = S(N - 1) + S(N -3)
对着图片看有助于理解
29.计算银行存款本息并输出。
输入银行存款金额(money)、存款周期(year)和年利率(rate),调用函数,计算存款到期时的本息合计(sum),输出本息合计金额(要求保留2位小数)
# include<stdio.h>
# include <math.h>
double xb(int m, int y, double r)//注意用double
{
return m*pow((1 + r),y);//题目给定的公式
}
int main ()
{
int m, y;
double r, sum;
scanf("%d %d %lf",&m,&y,&r);
printf ("sum=%.2lf",xb(m,y,r));
return 0;
}
30.十进制转化为二进制
#include<stdio.h>
#include<math.h>
int xb(int n)
{
int r = 1, i, a[1000];
for(i = 0; r!=0; i++)// for (i = 0; n > 0; n /= 2) a[i++] = n % 2; 更简洁,更秀
{
a[i] = n%2;
n = n/2;
r = n;
}
for(i--; i >= 0; i--)//注意第一个是 i--
printf("%d", a[i]);
}
int main()
{
int n;
scanf("%d",&n);
xb(n);
return 0;
}
/*# include<stdio.h>
int lyh(int n)
{
int a, b = 1;
while(b != 0)
{
a = n%2;
printf("%d",a);
n = n/2;
b = n;
}
}
int main (void)
{
int n;
scanf("%d", &n);
lyh(n);
return 0;
}//错误的进制转换,结果输出的是逆序
*/
//百度词条查找 十进制转二进制c语言表达 代码写的好
31.小母牛问题(解法二)
//递归法
# include<stdio.h>
int xb(int n)
{
if (n <=3 )
return 1;
else
return xb(n - 1) + xb(n - 3);
}
int main ()
{
int n;
scanf("%d",&n);
printf ("%d",xb(n));
return 0;
}