当前位置: 首页 > news >正文

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

相关文章:

  • 基于.Net Framework的N层分布式应用开发
  • Spring-mvc 静态资源不拦截
  • 一次CA证书服务器+IIS SSL的实验心得
  • 上传一下logo
  • java入门第一季5、6
  • Microsoft SQL Server 2005 提供了专用管理员连接 (DAC)
  • ES6, React, Redux, Webpack写的一个爬 GitHub 的网页
  • 第一次到这里来
  • RabbitMQ
  • 每天早晚二十分钟,让你人生从此不同
  • Json map
  • CSDN Blog更换服务器维护通知(今日21:00-22:00)
  • 初试牛刀的收获-实现Web文件的上传
  • 终于要毕业了,没有什么好说的
  • UITableViewCell 高度自适应
  • 345-反转字符串中的元音字母
  • DOM的那些事
  • express如何解决request entity too large问题
  • java架构面试锦集:开源框架+并发+数据结构+大企必备面试题
  • PHP 7 修改了什么呢 -- 2
  • Python3爬取英雄联盟英雄皮肤大图
  • Redis 中的布隆过滤器
  • thinkphp5.1 easywechat4 微信第三方开放平台
  • Vue组件定义
  • WebSocket使用
  • 从0实现一个tiny react(三)生命周期
  • 翻译--Thinking in React
  • 干货 | 以太坊Mist负责人教你建立无服务器应用
  • 码农张的Bug人生 - 初来乍到
  • 前端学习笔记之原型——一张图说明`prototype`和`__proto__`的区别
  • 《码出高效》学习笔记与书中错误记录
  • 哈罗单车融资几十亿元,蚂蚁金服与春华资本加持 ...
  • ###51单片机学习(2)-----如何通过C语言运用延时函数设计LED流水灯
  • ###STL(标准模板库)
  • #13 yum、编译安装与sed命令的使用
  • #DBA杂记1
  • #QT项目实战(天气预报)
  • (2)nginx 安装、启停
  • (AngularJS)Angular 控制器之间通信初探
  • (附源码)apringboot计算机专业大学生就业指南 毕业设计061355
  • (附源码)ssm教材管理系统 毕业设计 011229
  • (附源码)基于SpringBoot和Vue的厨到家服务平台的设计与实现 毕业设计 063133
  • (论文阅读11/100)Fast R-CNN
  • (牛客腾讯思维编程题)编码编码分组打印下标(java 版本+ C版本)
  • .gitignore
  • .NET 3.0 Framework已经被添加到WindowUpdate
  • .NET Core 项目指定SDK版本
  • .NET 分布式技术比较
  • .Net 知识杂记
  • .NET命名规范和开发约定
  • .vue文件怎么使用_vue调试工具vue-devtools的安装
  • /var/lib/dpkg/lock 锁定问题
  • @GlobalLock注解作用与原理解析
  • @Transaction注解失效的几种场景(附有示例代码)
  • [ 蓝桥杯Web真题 ]-布局切换