1. d=300000,p=6000,r=1%。
计算还清月数的公式如下:
可以将公式改成:
float d, p, r, m;
d = 300000;
p = 6000;
r = 0.01;
m = (log((p) / (p - d * r))) / (log(1 + r));
printf("%.1f\n",m);
return 0;
2. 给一个不多于5位的正整数,要求:
(1)求出它是几位数;
(2)分别输出每一位数字;
(3)按逆序输出各位数字。
#include<stdio.h>
#include<math.h>
int main()
{
int i, w, gw, sw, bw, qw, ww; //gw sw bw qw ww分别代表个位,十位,百位,千位,万位
printf("请输入一个正整数(1~99999):");
scanf_s("%d",&i);
while (i>99999)
{
printf("请重新输入正整数(1~99999):");
scanf_s("%d", &i);
}
if (i > 9999)
{
w = 5;
}
else if (i > 999)
{
w = 4;
}
else if (i>99)
{
w = 3;
}
else if (i>9)
{
w = 2;
}
else
{
w = 1;
}
printf("这个数是:%d 位数\n",w);
printf("输出每一位数字:");
ww = i / 10000;
qw = (i - ww * 10000) / 1000;
bw = (i - (ww * 10000 + qw * 1000)) / 100;
sw = (i - (ww * 10000 + qw * 1000 + bw * 100)) / 10;
gw = (i - (ww * 10000 + qw * 1000 + bw * 100 + sw * 10));
switch (w) //不同位数(5位,4位,3位,2位,1位)的数,逆序输出。用switch语句
{
case 5:
printf("%d %d %d %d %d\n", ww, qw, bw, sw, gw);
printf("逆序输出各位数字:");
printf("%d %d %d %d %d\n", gw, sw, bw, qw, ww); break;
case 4:
printf("%d %d %d %d\n", qw, bw, sw, gw);
printf("逆序输出各位数字:");
printf("%d %d %d %d\n", gw, sw, bw, qw); break;
case 3:
printf("%d %d %d\n", bw, sw, gw);
printf("逆序输出各位数字:");
printf("%d %d %d%\n", gw, sw, bw); break;
case 2:
printf("%d %d\n", sw, gw);
printf("逆序输出各位数字:");
printf("%d %d\n", gw, sw); break;
case 1:
printf("%d\n", gw);
printf("逆序输出各位数字:");
printf("%d\n", gw); break;
}
return 0;
}