mirror of
				https://github.com/aykhans/leet-code-problems.git
				synced 2025-10-26 04:29:19 +00:00 
			
		
		
		
	added is_valid_sudoku
This commit is contained in:
		| @@ -41,7 +41,7 @@ class AcceptedMedium: | |||||||
|             l2 = [] |             l2 = [] | ||||||
|         return [] if l[0] == '' else l |         return [] if l[0] == '' else l | ||||||
|  |  | ||||||
|     def convert_linear_str_to_zigzag(s: str, numRows: int) -> str: |     def convert_linear_str_to_zigzag(self, s: str, numRows: int) -> str: | ||||||
|         # sourcery skip: use-contextlib-suppress |         # sourcery skip: use-contextlib-suppress | ||||||
|         """ |         """ | ||||||
|             Link: https://leetcode.com/problems/zigzag-conversion/ |             Link: https://leetcode.com/problems/zigzag-conversion/ | ||||||
| @@ -77,4 +77,25 @@ class AcceptedMedium: | |||||||
|                     if l[j][i] is not None: |                     if l[j][i] is not None: | ||||||
|                         s2 += l[j][i] |                         s2 += l[j][i] | ||||||
|                 except IndexError: pass |                 except IndexError: pass | ||||||
|         return s1 + s2 + s3 |         return s1 + s2 + s3 | ||||||
|  |  | ||||||
|  |     def is_valid_sudoku(self, board: List[List[str]]) -> bool: | ||||||
|  |         # sourcery skip: list-comprehension, use-itertools-product | ||||||
|  |         for i in board: | ||||||
|  |             r = [j for j in i if j != '.' ] | ||||||
|  |             if len(set(r)) < len(r): return False | ||||||
|  |  | ||||||
|  |         for i in range(9): | ||||||
|  |             r = [board[j][i] for j in range(9) if board[j][i] != '.'] | ||||||
|  |             if len(set(r)) < len(r): return False | ||||||
|  |  | ||||||
|  |         for i in (0, 3, 6): | ||||||
|  |             for t in (0, 3, 6): | ||||||
|  |                 r = [] | ||||||
|  |                 for j in range(i, i+3): | ||||||
|  |                     for k in range(t, t+3): | ||||||
|  |                         if board[j][k] != '.': | ||||||
|  |                             r.append(board[j][k]) | ||||||
|  |                 if len(set(r)) < len(r): return False | ||||||
|  |  | ||||||
|  |         return True | ||||||
		Reference in New Issue
	
	Block a user
	 ayxan
					ayxan