본문 바로가기
알고리즘/leetcode

1706. Where Will the Ball Fall

by 유이얼 2022. 7. 31.
class Solution {
public:
    vector<int> findBall(vector<vector<int>>& grid) {
        int n = grid.size();
        int m = grid[0].size();
        
        vector<int> ans(m);
        for (int i = 0; i < m; ++i)
            ans[i] = i;
        
        for (int i = 0; i < n; ++i) {
            for (int j = 0; j < m; ++j) {
                int cur = ans[j];
                if (cur == -1) continue;
                
                int next = cur + grid[i][cur];
                if (next < 0 || m == next || grid[i][next] != grid[i][cur]) {
                    ans[j] = -1;
                    continue;
                }
                
                ans[j] = next;
            }
        }
        
        return ans;
    }
};

'알고리즘 > leetcode' 카테고리의 다른 글

621. Task Scheduler  (0) 2022.08.23
437. Path Sum III  (0) 2022.08.14
234. Palindrome Linked List  (0) 2022.07.30
14. Longest Common Prefix  (0) 2022.07.30
202. Happy Number  (0) 2022.07.27