2022/2/15、16——浙大版《C语言程序设计实验指导》《基础题集》PAT错题记

6-10 阶乘计算升级版 (20 分)

本题要求实现一个打印非负整数阶乘的函数。

函数接口定义:

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 分) 本题要求实现一个打印非负整数阶乘的函数。 - 代码先锋网

7-1 厘米换算英尺英寸 (15 分)

如果已知英制长度的英尺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;
}

7-2 然后是几点 (15 分)

有时候人们用四位数字表示一个时间,比如 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;
}

7-4 BCD解密 (10 分)

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;
}

今日总结:

呃,基础题集的最后几个函数题有点难,还没做出来,明天补上,要加油了!

你可能感兴趣的:(C语言程序设计,c语言)