本题要求实现一个打印非负整数阶乘的函数。
void Print_Factorial ( const int N );
其中N
是用户传入的参数,其值不超过1000。如果N
是非负整数,则该函数必须在一行中打印出N
!的值,否则打印“Invalid input”。
#include
void Print_Factorial ( const int N );
int main()
{
int N;
scanf("%d", &N);
Print_Factorial(N);
return 0;
}
/* 你的代码将被嵌在这里 */
15
1307674368000
//这道题在存储阶乘结果上有点难,呜呜,据说1000!的结果能有3000位,没有任何一个数据类型可以存放它,要用数组来存。看了好多别人写的,还是要自己在纸上模拟一下数字乘法的进位比较好。
//部分参考链接:
1.6-10 阶乘计算升级版(20 分) 本题要求实现一个打印非负整数阶乘的函数。 - 代码先锋网6-10 阶乘计算升级版(20 分) 本题要求实现一个打印非负整数阶乘的函数。,代码先锋网,一个为软件开发程序员提供代码片段和技术文章聚合的网站。https://www.codeleading.com/article/93142657866/
1. 6-10 阶乘计算升级版(20 分) 本题要求实现一个打印非负整数阶乘的函数。 - 代码先锋网2.
6-10 阶乘计算升级版(20 分) 本题要求实现一个打印非负整数阶乘的函数。_LIUJIALING_lala的博客-CSDN博客1. 6-10 阶乘计算升级版(20 分) 本题要求实现一个打印非负整数阶乘的函数。 - 代码先锋网
如果已知英制长度的英尺foot和英寸inch的值,那么对应的米是(foot+inch/12)×0.3048。现在,如果用户输入的是厘米数,那么对应英制长度的英尺和英寸是多少呢?别忘了1英尺等于12英寸。
输入在一行中给出1个正整数,单位是厘米。
在一行中输出这个厘米数对应英制长度的英尺和英寸的整数值,中间用空格分开。
170
5 6
//有点懵,没想出来,参考了别人的
//可以类比十进制的10.8,10 + 8/10
//由(foot+inch/12)×0.3048,1英尺等于12英寸(inch/12可转化为英尺数),可知英尺与米的换算比例为0.3048
//用 c/30.48赋给整型foot,只把整数部分赋给了他
//用(c / 30.48 - foot)得到小数部分,再*12获得英寸数值
int main()
{
int foot, inch;
int c;
scanf("%d", &c);
foot = c / 30.48;
inch = 12 * (c / 30.48 - foot);
printf("%d %d", foot, inch);
return 0;
}
有时候人们用四位数字表示一个时间,比如 1106
表示 11 点零 6 分。现在,你的程序要根据起始时间和流逝的时间计算出终止时间。
读入两个数字,第一个数字以这样的四位数字表示当前时间,第二个数字表示分钟数,计算当前时间经过那么多分钟后是几点,结果也表示为四位数字。当小时为个位数时,没有前导的零,例如 5 点 30 分表示为 530
;0 点 30 分表示为 030
。注意,第二个数字表示的分钟数可能超过 60,也可能是负数。
输入在一行中给出 2 个整数,分别是四位数字表示的起始时间、以及流逝的分钟数,其间以空格分隔。注意:在起始时间中,当小时为个位数时,没有前导的零,即 5 点 30 分表示为 530
;0 点 30 分表示为 030
。流逝的分钟数可能超过 60,也可能是负数。
输出不多于四位数字表示的终止时间,当小时为个位数时,没有前导的零。题目保证起始时间和终止时间在同一天内。
1120 110
1310
//time_h = time / 60;
time_m = time % 60;可以求出流逝的时分,且 分在-59----59之间
(start_m + time_m) >=-59 &&(start_m + time_m) <=118
(start_m + time_m - 60) <=58 (start_m + time_m + 60) >=1
最后输出是%d%02d
int main()
{
int start, time, start_h, start_m, time_h, time_m;
scanf("%d %d", &start, &time);
start_h = start / 100;
start_m = start % 100;
time_h = time / 60;
time_m = time % 60;
start_h += time_h;
if(time_m >= 0)
{
if(time_m + start_m < 60)
start_m += time_m;
else
{
start_h++;
start_m += time_m - 60;
}
}
else
{
start_h--;
start_m += time_m + 60;
}
printf("%d%02d", start_h, start_m);
return 0;
}
BCD数是用一个字节来表达两位十进制的数,每四个比特表示一位。所以如果一个BCD数的十六进制是0x12,它表达的就是十进制的12。但是小明没学过BCD,把所有的BCD数都当作二进制数转换成十进制输出了。于是BCD的0x12被输出成了十进制的18了!
现在,你的程序要读入这个错误的十进制数,然后输出正确的十进制数。提示:你可以把18转换回0x12,然后再转换回12。
输入在一行中给出一个[0, 153]范围内的正整数,保证能转换回有效的BCD数,也就是说这个整数转换成十六进制时不会出现A-F的数字。
输出对应的十进制数。
18
12
//输入在一行中给出一个[0, 153]范围内的正整数,其中最大的数153 %16 = 9, 153/16 = 9即最多两位每位最多为9,根据题意把10进制转换为16进制数再直接输出即可(看了别人的才作对)
#include
int main()
{
int a, b, c;
scanf("%d", &a);
b = a % 16;
c = a / 16 * 10 + b;
printf("%d", c);
return 0;
}
今日总结:
呃,基础题集的最后几个函数题有点难,还没做出来,明天补上,要加油了!