EOJ 1424/FOJ 1171/POJ 2572/ZOJ 1969/Ulm Local 2001 Hard to Believe, but True!

本文介绍了一种通过字符串处理和数值运算的方法来判断一个数学等式从右向左读取时是否仍然成立的技术。该方法首先反转等式中的数字,然后使用atoi函数将字符串转换为整数,并检查等式的正确性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目简介


给定一个等式,问等式从右往左读是否正确。

说明


题目不难,不过用到了一些有趣的字符串处理,所以记录下来。

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

void rev_str(char s[]){
    int c,i,j, len = strlen(s);
    for (i = 0, j = len - 1; i < j; i++, j--){
        c = s [i];
        s[i] = s[j];
        s[j] = c;
    }
}

int main()
{
    char str1[8]={0},str2[8]={0},str3[8]={0};
    while (~scanf("%[^+]+%[^=]=%s", str1, str2, str3)){
        rev_str(str1);rev_str(str2);rev_str(str3);
        if (atoi(str3) == atoi(str2) + atoi(str1))
            printf("True\n");
        else printf("False\n");

        if (atoi(str3) == 0 && atoi(str2) == 0 && atoi(str1) == 0) break;
    }
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值