2018-06-13

Q1:root to target 距离
Q2:检查graph是tree
Q3:count 2 sum 没有重复元素
Q4: count 2 sum, 重复元素只记录1次
Q5:count 2 sum,重复元素记录重数
Q6: leetcode, set matrix to 0
Q7:BST split
Q8: max product
Q9:max sub Array
Q10:加法实现乘除减

\\Q1
public int calDis(Node root, Node target) {
  return helper(root, target);
}

private int helper(Node cur, Node target) {
  if (cur == null) {
    return -1;
  }
  if (cur == target) {
    return 0;
  }
  int left = helper(cur.left, target);
  int right = helper(cur.right, target);
  if (left != -1 || right != -1) {
    return left != -1 ? left + 1 : right + 1;
  }
  return -1;
}

//Q2
public boolean isTree(int n, List<List<Integer>> egdes) {
  if (edges == null || edges.size() != n - 1) {
    return false;
  }
  Map<Integer, Integer> used = new HashMap<>();//val, freq
  for (List<Integer> edge: edges) {
    for (int v : edge) {
        int freq = used.getOrDefault(v, 0);
        used.put(v, freq + 1);
    }
  }
  return used.size() == n;
} 
//Q3
/*case 1 no dup in input*/
int i = 0;
int j = arr.length - 1;
int count = 0;
while (i < j) {
  int sum = arr[i] + arr[j];
  if (sum == target) {
    count++;
    i++; //没有dup时, 有没有j-- 都可以, 下一层自动handle
    j--;
  } else if (sum < target) {
    i++; 
  } else {
    j--;
  }
}

//Q4

int i = 0;
int j = arr.length - 1;
int count = 0;
while (i < j) {
  int sum = arr[i] + arr[j];
  if (sum == target) {
    count++;
    while (i + 1 < j && arr[i + 1] == arr[i]) {
      i++;
    }
    i++; //why 有这一个?
    /*上面的*/
  } else if (sum < target) {
    i++; 
  } else {
    j--;
  }
}
//Q5

int i = 0;
int j = arr.length - 1;
int count = 0;
while (i < j) {
  int sum = arr[i] + arr[j];
  if (sum == target) {
    int countI = 0;
    int countJ = 0;
    while (i + 1 < j && arr[i + 1] == arr[i]) {
      i++;
      countI++;
    }
     while (j - 1 > i && arr[j - 1] == arr[j]) {
      j--;
      countJ++;
    }
    i++;
    j--;
    count += (countI + 1) * (countJ + 1);

  } else if (sum < target) {
    i++; 
  } else {
    j--;
  }
}
//Q6
        public void setZeroes(int[][] matrix) {
            boolean hasZeroFirstRow = false;
            boolean hasZeroFirstCol = false;
            int m = matrix.length;
            int n = matrix[0].length;

            for (int i = 0; i < n; i++) {
                if (matrix[0][i] == 0) {
                    hasZeroFirstRow = true;
                    break;
                }
            }
            for (int i = 0; i < m; i++) {
                if (matrix[i][0] == 0) {
                    hasZeroFirstCol = true;
                    break;
                }
            }

            for (int i = 1; i < m; i++) {
                for (int j = 1; j < n; j++) {
                    if (matrix[i][j] == 0) {
                        matrix[0][j] = 0;
                        matrix[i][0] = 0;
                    }
                }
            }

            for (int i = 0; i < n; i++) {
                if (matrix[0][i] == 0) {
                    for (int j = 1; j < m; j++) {
                        matrix[j][i] = 0;
                    }
                }
            }

            for (int i = 0; i < m; i++) {
                if (matrix[i][0] == 0) {
                    for (int j = 1; j < n; j++) {
                        matrix[i][j] = 0;
                    }
                }
            }
            if (hasZeroFirstRow) {
                for (int j = 0; j < n; j++) {
                    matrix[0][j] = 0;
                }
            }
            if (hasZeroFirstCol) {
                for (int j = 0; j < m; j++) {
                    matrix[j][0] = 0;
                }
            }


        }
//Q7
public class BSTSplit {
    public TreeNode[]split(TreeNode root, int target) {

        if (root == null) {
            return null;
        }
       return helper(root, new TreeNode[]{null, null}, target);

    }

    private TreeNode[] helper(TreeNode cur, TreeNode[] result, int target){
        if (cur == null) {
            return new TreeNode[]{null, null};
        }

        if (cur.val > target) {

            cur.left = helper(cur.left, result, target)[1];

            cur.right = helper(cur.right, result, target)[1];
            result[1] = cur;
        } else {
            cur.left = helper(cur.left, result, target)[0];
            cur.right = helper(cur.right, result,target)[0];
            result[0] = cur;
        }
        return result;
    }
//Q8
public int findMax(int[] a){
        if (a == null || a.length == 0) {
            return -1;
        }
        int n = a.length;
        int[] dp = new int[n];
        int prefixProduct = 1;
        int result = -1;
        for (int i = 0; i < n; i++) {
            if (prefixProduct > 1) {
                dp[i] = prefixProduct * a[i];
            } else {
                dp[i] = a[i];
            }
            result = Math.max(dp[i], result);
        }
        return result;
    }
//Q9
public int maxProduct(int[] nums) {
            int n = nums.length;
            int maxPre = 1, minPre = 1;
            int result = Integer.MIN_VALUE;
            for (int i = 0; i < n; i++) {
                int temMax = Math.max(Math.max(maxPre * nums[i], nums[i]), minPre * nums[i]);
                minPre = Math.min(Math.min(minPre * nums[i], nums[i]), maxPre * nums[i]);

                maxPre = temMax;
                result = Math.max(maxPre, result);
            }
            return result;
        }
//Q10
  public int minus(int a, int b) {
        return add(a, ~b + 1);
    }

    public int multiple(int a, int b) {
        int result = 0;
        while ( b > 0) {
            result = add(result, a);
            b--;
        }
        return result;
    }

    public int divide(int a, int b) {
        int result = 0;

        while (a > 0) {
            a = minus(a, b);
            result++;
        }
        return result -1;
    }
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,716评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,558评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,431评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,127评论 0 209
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,511评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,692评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,915评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,664评论 0 202
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,412评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,616评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,105评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,424评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,098评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,096评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,869评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,748评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,641评论 2 271

推荐阅读更多精彩内容

  • Css动画: css3动画主要包括Transform、Transition、Animation 区别 transi...
    老头子_d0ec阅读 156评论 0 0
  • 一、wait--notify--sleep Object obj = new Object(); obj.wait...
    fe0180bd6eaf阅读 314评论 0 1
  • 在iOS实际开发中常用的动画无非是以下四种:UIView动画,核心动画,帧动画,自定义转场动画。下面我们逐个介绍。...
    4b5cb36a2ee2阅读 337评论 0 0
  • 001今天你思考了吗? 看到这个问题,很多人都笑了:我每天都在思考啊!可是,你的思考是独立完成的吗?所谓独立思考就...
    小小郁阅读 305评论 0 1
  • 她给我过生日,在学校里很多地方都竖起了大幕,在最空闲的地方搭了舞台,屏幕上放着我们过去的视频……我震惊于这个惊...
    小泥人pocky阅读 177评论 0 0