c - 为什么我的计算器函数没有返回正确的结果?

标签 c arithmetic-expressions

我是 C 编程语言新手。我正在创建一个简单的计算器程序,但由于某种原因我的函数没有返回正确的结果。这是我的程序:

#include <stdio.h>
#include <math.h>
#include <complex.h>
#include <string.h>


int calculator(int x, char operator, int y);
int main()
{
    int x;
    char operator;
    int y;

    printf("Enter an arithmetic experession: ");
    scanf("%d%s%d", &x, &operator, &y);

    int result = calculator(x, operator, y);

    if(result == -1)
    {
        printf("Error! Try again!");
    }
    else
    {

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


}
int calculator(int x, char operator, int y)
{
    int result = 0;
    if(y = 0)
    {
        return -1;
    }

    if(operator == '+')
    {
        result = x + y;
    }
    else if(operator == '-')
    {
        result = x - y;
    }
    else if(operator == '*')
    {
        result = x * y;
    }
    else if(operator == '/')
    {
        result = x / y;
    }
    else if(operator == '%')
    {
        result = x % y;
    }
    else
    {
        return -1;
    }

    return result;


}

所以当我运行这个程序时,它会要求一个算术表达式。如果我输入 5 + 3,它只返回 5!经过几次测试后,似乎无论如何它都只返回第一个操作数。我想这是一件非常小的事情,但我不明白我错过了什么。

最佳答案

两个问题。第一个是您在表达式中阅读的位置:

scanf("%d%s%d", &x, &operator, &y);

operator 是一个char,但您使用的是用于字符串的%s 格式说明符。这最终将运算符放入 operator 中,但随后将 NULL 终止符添加到内存中的下一个字节。由于该字节不是运算符的一部分,因此这会导致未定义的行为。

您想使用 %c 来读取单个字符。

第二个是对 y 进行零检查的位置:

if(y = 0)

这是一个作业,而不是比较。将值 0 分配给 y,然后将 y 计算为 bool 值,最终结果为 false。这就是为什么所有表达式的计算结果都如同 y 为 0。

将其更改为作业:

if(y == 0)

关于c - 为什么我的计算器函数没有返回正确的结果?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32814223/

相关文章:

java - 如何编写用于算术计算java解析器的递归while循环

c - GtkScale 小部件

c - 通过通用网络链接从内核到用户空间接收具有 2 个以上字段的结构时出现问题

c - C 中表达式必须具有常量值

c - C 中的整数溢出是如何工作的?

基于 Java 的表达式计算器

c - 段错误 - 自定义 Shell

c - boolean 抽象 C 程序

java - 如何用Java进行二进制算术运算?

bash - bash 中 $[a-b] 和 $((a-b)) 之间的区别