354. 俄罗斯套娃信封问题

  1. class Solution {
  2. public int maxEnvelopes(int[][] envelopes) {
  3. int ans = 1;
  4. if (envelopes == null || envelopes.length == 0 || envelopes[0].length != 2)
  5. return 0;
  6. Arrays.sort(envelopes, new Comparator<int[]>(){
  7. @Override
  8. // 先按照长递增排序(当长相同时按照宽递减排序)
  9. public int compare(int[] e1, int[] e2) {
  10. if (e1[0] == e2[0]) {
  11. return e2[1] - e1[1];
  12. } else {
  13. return e1[0] - e2[0];
  14. }
  15. }
  16. });
  17. int[] dp = new int[envelopes.length];
  18. dp[0] = 1;
  19. for (int i = 1; i < envelopes.length; i++) {
  20. dp[i] = 1;
  21. for (int j = 0; j < i; j++) {
  22. if (envelopes[i][1] > envelopes[j][1]) {
  23. dp[i] = Math.max(dp[i], dp[j] + 1);
  24. }
  25. }
  26. ans = Math.max(ans, dp[i]);
  27. }
  28. return ans;
  29. }
  30. }