C语言项目参考解答:全正整数后再计算

【项目-全正整数后再计算】(题目改编自对一位网络学员的辅导)
  输入3个正整数,其中任一数不是正整数,程序输出Invalid number!,然后结束运行。当第1个数为奇数时,计算后两数之和,当第1个数为偶数时,计算第2数减去第3数的差。无论哪种情形,当结果超过10时按如下示例输出,否则什么也不输出。
示例 1:
Enter number 1: 2
Enter number 2: -7
Invalid number!
示例2:
Enter number 1: 17
Enter number 2: 3
Enter number 3: 6
示例3:
Enter number 1: 16
Enter number 2: 3
Enter number 3: 6
示例4:
Enter number 1: 11
Enter number 2: 4
Enter number 3: 22
Result: 26
示例5:
Enter number 1: 246
Enter number 2: 22
Enter number 3: 4
Result: 18
示例6:
Enter number 1: 246
Enter number 2: 4
Enter number 3: 22

解法1:严格按题目描述来,先输入、再计算、最后输出,直观、清晰

#include <stdio.h>
#include <stdlib.h>

int main()
{
    int x,y,z,a;

    printf("Enter number 1:");
    scanf("%d",&x);

    if(x<=0)//第一个数字符号验证
    {
        printf("Invalid number.");
        return 0;
    }
    printf("Enter number 2: ");
    scanf("%d",&y);
    if(y<=0)
    {
        printf("Invalid number.\n");
        return 0;
    }
    printf("Enter the number 3: ");
    scanf("%d",&z);
    if(z<=0)
    {
        printf("Invalid number!\n");
        return 0;
    }
    if(x%2!=0)//第一个数字是奇数的情况
    {
        a=y+z;
    }
    else//第一个数字是偶数情况
    {
        a=y-z;
    }
    if(a>10)
    {
        printf("Paul is the monkey king,He can lift %d jin!",a);
    }
    return 0;
}

解法2:三级选择结构的嵌套,优先处理为正整数的情形

#include <stdio.h>
#include <stdlib.h>

int main()
{
    int x,y,z,a;

    printf("Enter number 1:");
    scanf("%d",&x);
    if(x>0)//第一个数字符号验证
    {
        printf("Enter number 2: ");
        scanf("%d",&y);
        if(y>0)
        {
            printf("Enter the number 3: ");
            scanf("%d",&z);
            if(z>0)
            {
                if(x%2!=0)
                    a=y+z;
                else
                    a=y-z;
                if(a>10)
                    printf("Result: %d\n",a);
            }
            else
                printf("Invalid number.\n");
        }
        else
            printf("Invalid number.\n");
    }
    else
        printf("Invalid number.\n");
    return 0;
}

解法3:用了一个技巧——变量ok初值为0,代表输入数字为非正整数,只有三数均为正整数后才赋值为1,这样,在程序结束之前,可以依据ok判定是否三数全是正整数

#include <stdio.h>
#include <stdlib.h>

int main()
{
    int x,y,z,a,ok=0;

    printf("Enter number 1:");
    scanf("%d",&x);
    if(x>0)
    {
        printf("Enter number 2: ");
        scanf("%d",&y);
        if(y>0)
        {
            printf("Enter the number 3: ");
            scanf("%d",&z);
            if(z>0)
            {
                ok=1;
                if(x%2!=0)
                    a=y+z;
                else
                    a=y-z;
                if(a>10)
                    printf("Result: %d\n",a);
            }
        }
    }
    if(ok==0) //若到此ok仍然为初值0,必定是某一个数非正整数了
        printf("Invalid number.\n");
    return 0;
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
正则表达式语法非常丰富,可以实现很多复杂的匹配和处理操作。虽然无法一一列举所有的语法,但我可以为您提供一些常用的语法元字符和模式: 1. 字符匹配: - 普通字符: 匹配与其自身相等的字符。 - . : 匹配除换行符外的任意字符。 - \d : 匹配任意数字字符。 - \w : 匹配任意字母、数字或下划线字符。 - \s : 匹配任意空白字符。 - [] : 匹配括号内的任意一个字符。 - [^] : 匹配除了括号内的字符以外的任意字符。 2. 重复匹配: - * : 匹配前面的字符0次或多次。 - + : 匹配前面的字符1次或多次。 - ? : 匹配前面的字符0次或1次。 - {n} : 匹配前面的字符恰好n次。 - {n,} : 匹配前面的字符至少n次。 - {n,m} : 匹配前面的字符至少n次但不超过m次。 3. 边界匹配: - ^ : 匹配字符串的开头。 - $ : 匹配字符串的结尾。 - \b : 匹配单词的边界。 4. 分组和捕获: - () : 将括号内的内容视为一个组。 - | : 匹配左右两边任意一个表达式。 - \1, \2, ... : 引用前面的分组,\1表示第一个分组,\2表示第二个分组,依此类推。 5. 其他元字符: - \ : 转义特殊字符。 - ^ : 在括号内表示取反。 - ? : 非贪婪匹配,尽可能少匹配字符。 - i : 忽略大小写匹配。 虽然这只是部分正则表达式语法的概述,但它们已经足够帮助您进行一些简单的正则匹配操作了。请根据您的需要选择适当的语法元字符和模式来编写您的正则表达式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

迂者-贺利坚

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值