zoukankan      html  css  js  c++  java
  • LC 990. Satisfiability of Equality Equations

    Given an array equations of strings that represent relationships between variables, each string equations[i] has length 4 and takes one of two different forms: "a==b" or "a!=b".  Here, a and b are lowercase letters (not necessarily different) that represent one-letter variable names.

    Return true if and only if it is possible to assign integers to variable names so as to satisfy all the given equations.

    Example 1:

    Input: ["a==b","b!=a"]
    Output: false
    Explanation: If we assign say, a = 1 and b = 1, then the first equation is satisfied, but not the second.  There is no way to assign the variables to satisfy both equations.
    

    Example 2:

    Input: ["b==a","a==b"]
    Output: true
    Explanation: We could assign a = 1 and b = 1 to satisfy both equations.
    

    Example 3:

    Input: ["a==b","b==c","a==c"]
    Output: true
    

    Example 4:

    Input: ["a==b","b!=c","c==a"]
    Output: false
    

    Example 5:

    Input: ["c==c","b==d","x!=z"]
    Output: true
    

    Note:

    1. 1 <= equations.length <= 500
    2. equations[i].length == 4
    3. equations[i][0] and equations[i][3] are lowercase letters
    4. equations[i][1] is either '=' or '!'
    5. equations[i][2] is '='
    Runtime: 12 ms, faster than 100.00% of C++ online submissions for Satisfiability of Equality Equations.
    Memory Usage: 7.1 MB, less than 100.00% of C++ online submissions for Satisfiability of Equality Equations.
    class Solution {
    
    private:
      int arr[26];
    public:
    
      void unionab(int a, int b) {
        arr[parent(a)] = arr[parent(b)];
      }
      int parent(int a) {
        if(arr[a] != a) return parent(arr[a]);
        return a;
      }
      bool uninit(int a) {
        return arr[a] == a ? true : false;
      }
      bool hassameroot(int a, int b) {
        return parent(a) == parent(b);
      }
    
      bool equationsPossible(vector<string>& equations) {
        for(int i=0; i<26; i++) arr[i] = i;
        for(int i=0; i<equations.size(); i++) {
          int a = ((int)equations[i][0] - (int)'a');
          int b = ((int)equations[i][3] - (int)'a');
          if ((int)equations[i][1] == (int)'=') {
            if(!hassameroot(a,b)) unionab(a,b);
          }
        }
        for(int i=0; i<equations.size(); i++) {
          int a = ((int)equations[i][0] - (int)'a');
          int b = ((int)equations[i][3] - (int)'a');
          if((int)equations[i][1] == (int)'!') {
            if(hassameroot(a,b)) return false;
          }
        }
        return true;
      }
    };
  • 相关阅读:
    【灵感】wifi通过wifi发送优惠信息
    Web 通信 之 长连接、长轮询(long polling)
    深入了解 Dojo 的服务器推送技术
    浅谈TCP优化
    非IE内核浏览器支持activex插件
    树莓派安装 Nginx + PHP7.0 + Pi Dashboard
    ChartView与LineSeries搭配实现曲线局部缩放功能
    QT开发(十二)——QT事件处理机制
    QT源码之Qt信号槽机制与事件机制的联系
    详解 QT 源码之 Qt 事件机制原理
  • 原文地址:https://www.cnblogs.com/ethanhong/p/10360001.html
Copyright © 2011-2022 走看看