【C语言入门】SDUT《程序设计基础I 》实验2-选择结构程序设计题解 && c语言语法讲解

题目链接

A - C语言实验——求绝对值(选择结构)

使用if选择语句, 大于等于 0 直接输出, 小于 0 输出 -x 即可

拓展: 求绝对值的函数

<math.h>头文件下有abs() 和 fabs() 两个函数, 分别可以返回整数和浮点型的原数的绝对值

code A

//if分支语句
#include <stdio.h>

int main()
{
    int x;
    scanf("%d", &x);

    if(x >= 0) printf("%d", x);
    else printf("%d", -x);
    return 0;
}
//使用abs()函数
#include <stdio.h>
#include <math.h>
int main()
{
    int x;
    scanf("%d", &x);

    printf("%d", abs(x));
    return 0;
}

B - C语言实验——时间间隔

  • 我们可以使用统一单位的方法, 把两个时间段统一化成秒为单位
  • 根据两个时间化成秒后的大小, 可以通过交换, 让较小的时间在前面
  • 将两个时间作差得到两个时间的差值, 再将其还原成小时和分钟
  • 时间是60进制, 可以类比10进制的方式思考
  • 一个三位的十进制数, % 10 得到的是个位, / 10 得到的是个位之前的数, / 100得到的是百位, % 100 得到的是去掉最高位后剩下的数, 如123, 百位为123 / 100 = 1, 个位为123 % 10 = 3, 可以理解成, /10就是从十位切一刀, 然后取前半部分; 而 %10 相当于从10位切一刀, 然后取后半部分, 这样想得到中间的数字, 可以从后往前取, 也就是123 / 10 = 12, 12 % 10 = 2; 也可以从前往后取, 也就是123 % 100 = 23, 23 / 10 = 2;
  • 按照同样的方式, 从我们已经得到的10进制的时间差, 转换为3位(时、分、秒) 的60进制 时间, 记时间差为t, 时 = t / 3600, 秒 = t % 60, 分 = t / 60 % 60 (从后往前) 或 分 = t % 3600 / 60(从前往后)

code B

#include <stdio.h>

int main()
{
    int h1, m1, s1; //第一个时间的时分秒
    int h2, m2, s2; //第二个时间的时分秒

    scanf("%d:%d:%d", &h1, &m1, &s1);
    scanf("%d:%d:%d", &h2, &m2, &s2);

    int t1 = h1 * 3600 + m1 * 60 + s1;
    int t2 = h2 * 3600 + m2 * 60 + s2; //将两个时间转换成以秒为单位

    if(t1 > t2) //如果t1大,交换t1和t2,目的是让t2 >= t1, 直接用t2 - t1求时间差 (当然也可以用abs(t1 - t2)求时间差) 
    {
        int t = t1;
        t1 = t2;
        t2 = t;
    }

    int t = t2 - t1; //t为时间差, 交换后t2一定比t1大

    printf("%02d:%02d:%02d", t / 3600, t / 60 % 60, t % 60);
    return 0;
}

C - C语言实验——求两个整数之中较大者

用if来判断较大值即可

code C

#include <stdio.h>

int main()
{
    int a, b, max;
    scanf("%d %d", &a, &b);
    if(a > b) max = a;
    else max = b;
    printf("max=%d", max); 
    return 0;
}

D - 小鑫吃苹果

跟上题相同, 都是找两个数的最大值, 直接if比较即可

code D

#include <stdio.h>

int main()
{
    int a, b, max;
    scanf("%d %d", &a, &b);
    if(a > b) max = a;
    else max = b;
    printf("%d", max); 
    return 0;
}

E - 小鑫の日常系列故事(一)——判断对错

仍然是直接用if判断c是否等于a + b之和

code E

#include <stdio.h>

int main()
{
    int a, b, c;
    scanf("%d %d %d", &a, &b, &c);
    if(c == a + b) printf("YES\n");
    else printf("NO\n");
    return 0;
}

F - 小鑫追女神

判断输入是0是1即可, 可以直接用简写, if(n) 表示n != 0, if(!n) 表示n == 0

code F

#include <stdio.h>

int main()
{
    int n;
    scanf("%d", &n);
    if(n) printf("I like you");
    else printf("He he");
    return 0;
}

G - C语言实验——求三个整数的最大值

可以对三个数排序, 排序完之后最大值最小值中间值就都可以求了;
也可以用打擂法来求max,min, 也就是初始化一个非常小的max(非常大的min), 遇到更大的(更小的)更新这个值, 最后留下的即为这些值全部的最大值or最小值, 在循环和数组章节中会经常见到打擂法

知识点: 三个数排序

对三个数排序, 最多需要3个if即可, 首先比较ab, 然后比较bc, 最后再比较一次ab
如要让a b c从小到大排序 (a < b < c)
首先比较是否a > b, 如果是则交换a b, 交换后b的值为a和b中的较大值
然后比较是否b > c, 如果是则交换b c, 交换后c的值为b和c中的较大值, 此时的c一定为a b c中的最大值
最后比较是否a > b, 如果是则交换a b, 交换后满足a <= b, 而c已经确保为三个数中的最大值了, 排序完成

code G

//排序
#include <stdio.h>

int main()
{
    int a, b, c;
    scanf("%d,%d,%d", &a, &b, &c);
    
    if(a > b)
    {
        int t = a;
        a = b;
        b = t;
    } 
    if(b > c)
    {
        int t = b;
        b = c;
        c = t;
    } 
    if(a > b)
    {
        int t = a;
        a = b;
        b = t;
    }
    printf("max=%d", c); //交换完之后c为max
    return 0;
}
//打擂法可以求max或者min
#include <stdio.h>

int main()
{
    int a, b, c;
    scanf("%d,%d,%d", &a, &b, &c);
    int max = -2e9; // 表示2 * 10的9次方, 为max初始化一个极小的数
    if(a > max) max = a;
    if(b > max) max = b;
    if(c > max) max = c;
    printf("max=%d", max); //交换完之后c为max
    return 0;
}

H - 相加和最大值

可以对三个数排序, 最大的两个数相加的和一定是最大的;
也可以分别两两求和, 再求最大值

code H

#include <stdio.h>

int main()
{
    int a, b, c;
    scanf("%d %d %d", &a, &b, &c);
    if(a > b)
    {
        int t = a;
        a = b;
        b = t;
    } 
    if(b > c)
    {
        int t = b;
        b = c;
        c = t;
    } 
    if(a > b)
    {
        int t = a;
        a = b;
        b = t;
    }
    printf("%d", b + c); //最大俩数加起来一定是最大的和
    return 0;
}
//俩俩求和, 这里还是用的与上题相同的打擂法的思想
#include <stdio.h>

int main()
{
    int a, b, c;
    scanf("%d %d %d", &a, &b, &c);
    int max = -2e9; // 表示2 * 10的9次方, 为max初始化一个极小的数
    if(a + b > max) max = a + b;
    if(b + c > max) max = b + c;
    if(c + a > max) max = c + a;
    printf("%d", max); 
    return 0;
}

I - 时间格式转换

只需要分类表示每一种情况即可, 注意用%02d控制输出的格式, 这个题时不能用%02d,分需要用%02d

code I

//简化版, 需要处理好边界
#include <stdio.h>

int main()
{
    int h, m;
    scanf("%d:%d", &h, &m);

    int hh, mm = m;//转换后的时和分, 分和原来的分相同
    //按照h来分类
    if(h == 0 || h == 12) hh = 12; //h = 0和h = 12两个条件可以合并
    else if(h <= 11) hh = h; //h >= 1这个条件可以省略不写
    else hh = h - 12; //除此之外的时间即为h >= 13 到 h <= 23之内的

    if(h < 12) printf("%d:%02d AM", hh, mm); //注意后面的AM和PM
    else printf("%d:%02d PM", hh, mm);
    
    return 0;
}
//详细版, 如果不好考虑边界条件可以完完全全按照题目说的来写
#include <stdio.h>

int main()
{
    int h, m;
    scanf("%d:%d", &h, &m);

    int hh, mm;

    if(h == 0) hh = 12;
    else if(h >= 1 && h <= 11) hh = h;
    else if(h == 12) hh = 12;
    else if(h >= 13 && h <= 24) hh = h - 12;
    
    mm = m;
    if((h == 0) || (h >= 1 && h <= 11)) printf("%d:%02d AM", hh, mm);
    if((h == 12) || (h >= 13 && h <= 23)) printf("%d:%02d PM", hh, mm);
    return 0;
}

J - C语言实验——从大到小输出a、b、c(选择结构)

按照G思路对三个数排序即可

code J

#include <stdio.h>

int main()
{
    int a, b, c;
    scanf("%d%d%d", &a, &b, &c);
    if(a > b)
    {
        int t = a;
        a = b;
        b = t;
    }
    if(b > c)
    {
        int t = b;
        b = c;
        c = t;
    }
    if(a > b)
    {
        int t = a;
        a = b;
        b = t;
    }
    printf("%d %d %d", c, b, a);
    return 0;
}

K - C语言实验——三个数排序

与上一个题完全相同, 输入中间是逗号

code K

#include <stdio.h>

int main()
{
    int a, b, c;
    scanf("%d,%d,%d", &a, &b, &c);
    if(a > b)
    {
        int t = a;
        a = b;
        b = t;
    }
    if(b > c)
    {
        int t = b;
        b = c;
        c = t;
    }
    if(a > b)
    {
        int t = a;
        a = b;
        b = t;
    }
    printf("%d %d %d", a, b, c);
    return 0;
}

L - C语言实验——找中间数

仍像G或前两个题一样, 对三个数进行排序, 输出中间值即可

code L

#include <stdio.h>

int main()
{
    int a, b, c;
    scanf("%d%d%d", &a, &b, &c);
    if(a > b)
    {
        int t = a;
        a = b;
        b = t;
    }
    if(b > c)
    {
        int t = b;
        b = c;
        c = t;
    }
    if(a > b)
    {
        int t = a;
        a = b;
        b = t;
    }
    printf("%d", b);
    return 0;
}

M - C语言实验——整除

用&&(与)把两个条件连起来即可

ps: 当你找不到wa哪里的时候不妨看看是不是输出大小写的问题

code M


#include <stdio.h>

int main()
{
    int n;
    scanf("%d", &n);
    if(n % 5 == 0 && n % 3 == 0) printf("Yes");
    else printf("No");
    return 0;
}

N - 闰年

判断闰年的条件: 能被400整除 或者 能被4整除但不能被100整除

code N

#include <stdio.h>

int main()
{
    int n;
    scanf("%d", &n);
    if(n % 400 == 0 || n % 4 == 0 && n % 100) printf("Yes");
    else printf("No");
    return 0;
}

O - C/C++经典程序训练3—模拟计算器

知识点: 吃掉行末空格

scanf %c 不会跳过空白符(如空格’ ‘或换行符’\n’), 因此当数字后面有换行符(或空格)而后需要读入字母的时候需要吃掉行末换行符(空格符)

  • 可以用getchar()直接吃掉行末的换行或者空格
  • 可以设一个无关char类型变量, 然后用scanf %c 吃掉换行或者空格
code O
#include <stdio.h>

int main()
{
    int a, b;
    char c;
    scanf("%d%d", &a, &b);
    getchar(); //吃掉行末换行
    scanf("%c", &c);

    int ans;
    if(c == '+') ans = a + b;
    else if(c == '-') ans = a - b;
    else if(c == '*') ans = a * b;
    else ans = a / b;

    printf("%d", ans); 
    return 0;
}

P - C语言实验——某年某月的天数

注意判断闰年即可
可以用switch case语句来写, 注意在除最后一个分支下添加break即可

code P

#include <stdio.h>
int main()
{
    int y, m;
    scanf("%d\\%d", &y, &m);

    if(m == 1 || m == 3 || m == 5 || m == 7 || m == 8 || m == 10 || m == 12) printf("31");
    else if(m == 4 || m == 6 || m == 9 || m == 11) printf("30");
    else //二月需要特别处理
    {
        if(y % 400 == 0 || y % 4 == 0 && y % 100 != 0) printf("29");
        else printf("28");
    }
    return 0;
}
//switch case写
#include <stdio.h>
int main()
{
    int y, m;
    scanf("%d\\%d", &y, &m);

    switch(m)
    {
        case 1: case 3: case 5: case 7: case 8: case 10: case 12:
            printf("31");
            break;
        case 4: case 6: case 9: case 11:
            printf("30");
            break;
        default:
            if(y % 400 == 0 || y % 4 == 0 && y % 100 != 0) printf("29");
            else printf("28");
    }
    
    return 0;
}

Q - C语言实验——输入数字星期,输出英文(switch语句)

  • switch-case 语句记得在除了最后一条分支以外的所有分支加上break, break相当于switch的开关,不加的话switch会一直往下滑, 并输出滑过的所有结果

code Q

#include <stdio.h>
int main()
{
    int d;
    scanf("%d", &d);

    switch(d)
    {
        case 1: 
            printf("Monday");
            break;
        case 2:
            printf("Tuesday");
            break;
        case 3:
            printf("Wednesday");
            break;
        case 4:
            printf("Thursday");
            break;
        case 5:
            printf("Friday");
            break;
        case 6:
            printf("Saturday");
            break;
        case 7: //可以写default
            printf("Sunday"); //最后一个可以不加break
    }
    return 0;
}

题解仅供参考, 一定要多敲多思考!!! 有问题欢迎在评论区指出或单独联系我!

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值