返回介绍

solution / 1400-1499 / 1440.Evaluate Boolean Expression / README

发布于 2024-06-17 01:03:19 字数 3190 浏览 0 评论 0 收藏 0

1440. 计算布尔表达式的值

English Version

题目描述

Variables:

+---------------+---------+
| Column Name   | Type  |
+---------------+---------+
| name      | varchar |
| value     | int   |
+---------------+---------+
在 SQL 中,name 是该表主键.
该表包含了存储的变量及其对应的值.

 

Expressions:

+---------------+---------+
| Column Name   | Type  |
+---------------+---------+
| left_operand  | varchar |
| operator    | enum  |
| right_operand | varchar |
+---------------+---------+
在 SQL 中,(left_operand, operator, right_operand) 是该表主键.
该表包含了需要计算的布尔表达式.
operator 是枚举类型, 取值于('<', '>', '=')
left_operand 和 right_operand 的值保证存在于 Variables 表单中.

 

计算表 Expressions 中的布尔表达式。

返回的结果表 无顺序要求

结果格式如下例所示。

 

示例 1:

输入:
Variables 表:
+------+-------+
| name | value |
+------+-------+
| x  | 66  |
| y  | 77  |
+------+-------+

Expressions 表:
+--------------+----------+---------------+
| left_operand | operator | right_operand |
+--------------+----------+---------------+
| x      | >    | y       |
| x      | <    | y       |
| x      | =    | y       |
| y      | >    | x       |
| y      | <    | x       |
| x      | =    | x       |
+--------------+----------+---------------+

输出:
+--------------+----------+---------------+-------+
| left_operand | operator | right_operand | value |
+--------------+----------+---------------+-------+
| x      | >    | y       | false |
| x      | <    | y       | true  |
| x      | =    | y       | false |
| y      | >    | x       | true  |
| y      | <    | x       | false |
| x      | =    | x       | true  |
+--------------+----------+---------------+-------+
解释:
如上所示, 你需要通过使用 Variables 表来找到 Expressions 表中的每一个布尔表达式的值.

解法

方法一:等值连接 + CASE 表达式

我们可以通过等值连接,将 Expressions 表中的每一行与 Variables 表中的两行进行关联,关联的条件是 left_operand = nameright_operand = name,然后通过 CASE 表达式来判断布尔表达式的值。如果 operator=,则判断两个值是否相等;如果 operator>,则判断左值是否大于右值;如果 operator<,则判断左值是否小于右值。若是,那么布尔表达式的值为 true,否则为 false

# Write your MySQL query statement below
SELECT
  left_operand,
  operator,
  right_operand,
  CASE
    WHEN (
      (operator = '=' AND v1.value = v2.value)
      OR (operator = '>' AND v1.value > v2.value)
      OR (operator = '<' AND v1.value < v2.value)
    ) THEN 'true'
    ELSE 'false'
  END AS value
FROM
  Expressions AS e
  JOIN Variables AS v1 ON e.left_operand = v1.name
  JOIN Variables AS v2 ON e.right_operand = v2.name;

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文