• 2017/11/21 Leetcode 日记


    2017/11/21 Leetcode 日记

     496. Next Greater Element I

    You are given two arrays (without duplicates) nums1 and nums2 where nums1’s elements are subset of nums2. Find all the next greater numbers for nums1's elements in the corresponding places of nums2.

    The Next Greater Number of a number x in nums1 is the first greater number to its right in nums2. If it does not exist, output -1 for this number.

    class Solution {
    public:
        vector<int> nextGreaterElement(vector<int>& findNums, vector<int>& nums) {
            vector<int> tNums;
            for(int i = 0, sz = findNums.size(); i < sz; i++){
                bool finded = false;
                int index = 0;
                for(int j = findN(findNums[i], nums), nsz = nums.size(); j < nsz; j++){
                    if(nums[j] > findNums[i]){
                        index = j;
                        break;
                    }
                }
                if(index == 0) tNums.push_back(-1);
                else tNums.push_back(nums[index]);
            }
            return tNums;
        }
        // return index of nums[k] == num
        int findN(int num, vector<int>& nums){
            for(int i = 0, sz = nums.size(); i < sz; i++){
                if(nums[i] == num){
                    return i;
                }
            }
            return -1;
        }
    };
    c++

    513. Find Bottom Left Tree Value

    Given a binary tree, find the leftmost value in the last row of the tree.

     (BFS)

    /**
     * Definition for a binary tree node.
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
     * };
     */
    class Solution {
    public:
        int findBottomLeftValue(TreeNode* root) {
            queue<TreeNode*> leaves;
            leaves.push(root);
            while(!leaves.empty()){
                TreeNode *temp = leaves.front();leaves.pop();
                if(!temp->right && !temp->left && leaves.empty()) return temp->val;
                if(temp->right)
                    leaves.push(temp->right);
                if(temp->left)
                    leaves.push(temp->left);
            }
        }
    };
    c++
    # Definition for a binary tree node.
    # class TreeNode:
    #     def __init__(self, x):
    #         self.val = x
    #         self.left = None
    #         self.right = None
    
    class Solution:
        def findBottomLeftValue(self, root):
            """
            :type root: TreeNode
            :rtype: int
            """
            list = []
            list.append(root)
            while(len(list)):
                temp = list.pop(0)
                if(temp.right == None and temp.left == None and len(list) == 0):
                    return temp.val
                if(temp.right):
                    list.append(temp.right)
                if(temp.left):
                    list.append(temp.left)
            
    python3

    540. Single Element in a Sorted Array

    Given a sorted array consisting of only integers where every element appears twice except for one element which appears once. Find this single element that appears only once.

     (二分搜索)

    class Solution {
    public:
        int singleNonDuplicate(vector<int>& nums) {
            int left = 0, right = nums.size()-1;
            int mid = (left + right) / 2;
            if(mid == left) return nums[mid];
            while(left < right){
                if(mid % 2 == 0){
                    if(Left(mid, nums)) {
                        right = mid-1;
                        mid = (right + left)/2;
                    }
                    else if(Right(mid, nums)){
                        left = mid+1;
                        mid = (left + right)/2;
                    }
                    else return nums[mid];
                }else{
                    if(Left(mid, nums)){
                        left = mid+1;
                        mid = (left + right)/2;
                    }else{
                        right = mid-1;
                        mid = (right + left)/2;
                    }
                }
            }
            return nums[mid];
        }
        
        bool Left(int i, vector<int>& nums){
            int left = 0;
            if(i == 0) return false;
            else if (nums[i] != nums[i-1]) return false;
            else return true;
        }
        
        bool Right(int i, vector<int>& nums){
            int right = nums.size()-1;
            if (i == right) return false;
            else if (nums[i] != nums[i+1]) return false;
            else return true;
        }
    };
    c++

    647. Palindromic Substrings

    Given a string, your task is to count how many palindromic substrings in this string.

    The substrings with different start indexes or end indexes are counted as different substrings even they consist of same characters.

    class Solution {
    public:
       int countSubstrings(string s) {
            int left = 0, right = s.size();
            // cout<<right<<endl;
            // return traceBack(s, left, right);
            int count = 0;
            for(int i = left; i < right; i++){
                for(int j = i; j < right; j++){
                    bool palindromic = true;
                    for(int ind = i, end = j; ind <= end; ind++, end--){
                        if(s[ind] != s[end]) palindromic = false;
                    }
                    if(palindromic) count++;
                }
            }
            return count;
        }
    };
    c++

    637. Average of Levels in Binary Tree

    Given a non-empty binary tree, return the average value of the nodes on each level in the form of an array.

    /**
     * Definition for a binary tree node.
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
     * };
     */
    class Solution {
    public:
        vector<double> averageOfLevels(TreeNode* root) {
            queue<TreeNode*> q;
            queue<long long> level;
            vector<double> ave;
            
            q.push(root);
            level.push(0);
            long long last = 0, sum = 0, num = 0;
            while(!q.empty()){
                TreeNode * temp = q.front();q.pop();
                long long tp = level.front(); level.pop();
                
                if(temp->right) {q.push(temp->right);level.push(tp+1);}
                if(temp->left)  {q.push(temp->left);level.push(tp+1);}
                
                if(tp == last){
                    sum += temp->val;
                    num ++;
                }else{
                    ave.push_back((double)sum/(double)num);
                    sum = 0;
                    num = 1;
                    last = tp;
                    sum += temp->val;
                }
                if(q.empty()) ave.push_back((double)sum/(double)num);
            }
            return ave;
        }
    };
    c++

    515. Find Largest Value in Each Tree Row

    You need to find the largest value in each row of a binary tree.

    /**
     * Definition for a binary tree node.
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
     * };
     */
    class Solution {
    public:
        vector<int> largestValues(TreeNode* root) {
            queue<TreeNode*> q;
            queue<int> level;
            vector<int> ave;
            
            if(root == NULL) return ave;
            
            q.push(root);
            level.push(0);
            int last = 0, max = -(1<<31);
            while(!q.empty()){
                TreeNode * temp = q.front();q.pop();
                int tp = level.front(); level.pop();
                
                if(temp->right) {q.push(temp->right);level.push(tp+1);}
                if(temp->left)  {q.push(temp->left);level.push(tp+1);}
                
                if(tp == last){
                    if(max < temp->val)
                        max = temp->val;
                }else{
                    ave.push_back(max);
                    max = -(1<<31);
                    last = tp;
                    if(max < temp->val)
                        max = temp->val;
                }
                if(q.empty()) ave.push_back(max);
            }
            return ave;
        }
    };
    c++
  • 相关阅读:
    基于docker安装pxc集群
    PXC集群的概述及搭建
    十,StatefulSet简介及简单使用
    九,configMap及secret的基本使用
    八,kubernetes集群存储卷基础。
    七,ingress及ingress cluster
    六,k8s集群service资源
    mysql的优化
    ORACLE11g:No Dialect mapping for JDBC type: -9解决方案
    Oracle数据库的分页
  • 原文地址:https://www.cnblogs.com/yoyo-sincerely/p/7871786.html
Copyright © 2020-2023  润新知