牛客网刷题:BC49 kiki算数

描述

问题:KiKi今年5岁了,已经能够认识100以内的非负整数,并且并且能够进行 100 以内的非负整数的加法计算。不过,BoBo老师发现KiKi在进行大于等于100的正整数的计算时,规则如下:

1.       只保留该数的最后两位,例如:对KiKi来说1234等价于34;

2.       如果计算结果大于等于 100, 那么KIKI也仅保留计算结果的最后两位,如果此两位中十位为0,则只保留个位。

例如:45+80 = 25

要求给定非负整数 a和 b,模拟KiKi的运算规则计算出 a+b 的值。

输入描述:

一行,输入两个非负整数a和b,用一个空格分隔。(0 <= a,b<= 231-1)。

输出描述:

针对每组输入,输出按照KiKi的运算规则计算出 a+b 的值。

 


分析:

定义变量

用户输入

取模运算

 对本题而言,由于计算过程只是每个数字的后两位参与,根据加法的性质,直接对(a+b)%100结果也是等价的。


# include <stdio.h>
int main ()
{
    int a,b;
    scanf("%d %d",&a,&b);
    int ret = a+b;
    if(ret<=99)//小于99 直接打印
    {
        printf("%d",ret);
    }
    else//否则 取模100 假如123 那就是 23
    {
        printf("%d",ret%100);
    
    }
    return 0;
}

官方代码:

#include <bits/stdc++.h>
using namespace std;

int main() {
    int a = 0, b = 0;
    scanf("%d %d", &a, &b);
    printf("%d\n", (a+b)%100);
    return 0;
}

关于C语言中的取模运算 

通常取模运算也叫取余运算,它们返回结果都是余数 .rem 和 mod 唯一的区别在于:

当 x 和 y 的正负号一样的时候,两个函数结果是等同的;

当 x 和 y 的符号不同时,rem 函数结果的符号和 x 的一样,而 mod 和 y 一样。

这是由于这两个函数的生成机制不同,rem 函数采用 fix 函数,而 mod 函数采用了 floor 函数(这两个函数是用来取整的,fix 函数向 0 方向舍入,floor 函数向无穷小方向舍入)。

rem(x,y)命令返回的是 x-n.*y,如果 y 不等于 0,其中的 n = fix(x./y),而 mod(x,y) 返回的是 x-n.*y,当 y 不等于 0 时,n=floor(x./y)

两个异号整数取模取值规律 (当是小数时也是这个运算规律,这一点好像与 C 语言的不太一样)

先将两个整数看作是正数,再作除法运算:

  • 1、能整除时,其值为 0
  • 2、不能整除时,其值=除数×(整商+1)-被除数

例:mod(36,-10)=-4

即:36 除以 10 的整数商为 3,加 1 后为 4;其与除数之积为 40;再与被数之差为(40-36=4);取除数的符号。所以值为 -4。

例:mod(9,1.2)=0.6;

例:

>> mod(5,2)
ans =1                   % 除数是正,余数就是正
>> mod(-5,2)
ans =1
>> mod(5,-2)
ans =-1                  % 除数是负,余数就是负
>> mod(-5,-2)
ans =-1                  % 用 rem 时,不管除数是正是负,余数的符号与被除数的符号相同
>> rem(5,2)
ans =1                   % 被除数是正,余数就是正
>> rem(5,-2); 
ans =1
>> rem(-5,2)
ans =-1                 % 被除数是负, 余数就是负
>> rem(-5,-2)
ans =-1

 

以上来自 菜鸟教程网站

取余和取模的区别 | 菜鸟教程 (runoob.com)

Hello,各位读者朋友们你们好,欢迎来到 从0至1 的CSDN博客。

一个喜欢文学的理科男,欢迎大家关注我的矩阵平台!

欢迎关注我的短视频矩阵:

微信公众平台:从0至1

今日头条:从0至1

百家号(百度APP):小飞从0至1

抖音:从0至1

小红书:从0至1

知乎:从0至1

CSDN:https://blog.csdn.net/m0_64000959?spm=1000.2115.3001.5343

Gitee:https://gitee.com/from-0-to-1

后续继续更新......

  • 30
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值