LeetCode - Best Time to Buy and Sell Stock II | Darren's Blog



Say you have an array for which the ith element is the price of a given stock on day i. Design an algorithm to find the maximum profit. You may complete as many transactions as you like (ie, buy one and sell one share of the stock multiple times). However, you may not engage in multiple transactions at the same time (ie, you must sell the stock before you buy again)
To avoid multiple simultaneous transactions, we consider buying the stock on day i and selling it on day i+1 . If this brings in profit, i.e. price[i]<price[i+1] , we do it. If that is the case, Otherwise, we are safe to move to the next day, since we can buy the stock at a price not greater than that on day i.
public int maxProfit(int[] prices) {
        if (prices == null || prices.length == 0)
            return 0;
 
        int maximumProfit = 0;  // Maximum profit up to now
 
        // If buying the stock on day i and selling it on day i+1 brings in profit, do it.
        // The only possible scenario that withdraws it is that buying on day i+1 and selling
        // it on day i+2 also brings in profit. In that case it is equivalent to buying it
        // on day i and selling it on day i+2
        for (int i = 0; i < prices.length-1; i++)
            maximumProfit += Math.max(prices[i+1]-prices[i], 0);
 
        return maximumProfit;
    }
Read full article from LeetCode - Best Time to Buy and Sell Stock II | Darren's Blog

No comments:

Post a Comment

Labels

Algorithm (219) Lucene (130) LeetCode (97) Database (36) Data Structure (33) text mining (28) Solr (27) java (27) Mathematical Algorithm (26) Difficult Algorithm (25) Logic Thinking (23) Puzzles (23) Bit Algorithms (22) Math (21) List (20) Dynamic Programming (19) Linux (19) Tree (18) Machine Learning (15) EPI (11) Queue (11) Smart Algorithm (11) Operating System (9) Java Basic (8) Recursive Algorithm (8) Stack (8) Eclipse (7) Scala (7) Tika (7) J2EE (6) Monitoring (6) Trie (6) Concurrency (5) Geometry Algorithm (5) Greedy Algorithm (5) Mahout (5) MySQL (5) xpost (5) C (4) Interview (4) Vi (4) regular expression (4) to-do (4) C++ (3) Chrome (3) Divide and Conquer (3) Graph Algorithm (3) Permutation (3) Powershell (3) Random (3) Segment Tree (3) UIMA (3) Union-Find (3) Video (3) Virtualization (3) Windows (3) XML (3) Advanced Data Structure (2) Android (2) Bash (2) Classic Algorithm (2) Debugging (2) Design Pattern (2) Google (2) Hadoop (2) Java Collections (2) Markov Chains (2) Probabilities (2) Shell (2) Site (2) Web Development (2) Workplace (2) angularjs (2) .Net (1) Amazon Interview (1) Android Studio (1) Array (1) Boilerpipe (1) Book Notes (1) ChromeOS (1) Chromebook (1) Codility (1) Desgin (1) Design (1) Divide and Conqure (1) GAE (1) Google Interview (1) Great Stuff (1) Hash (1) High Tech Companies (1) Improving (1) LifeTips (1) Maven (1) Network (1) Performance (1) Programming (1) Resources (1) Sampling (1) Sed (1) Smart Thinking (1) Sort (1) Spark (1) Stanford NLP (1) System Design (1) Trove (1) VIP (1) tools (1)

Popular Posts