Giả sử chúng ta có một số nguyên n, trong đó chỉ có 1, 2 và 3 các chữ số này có mặt. Chúng ta có thể lật một chữ số thành một chữ số 3. Sau đó, tìm số lớn nhất mà chúng ta có thể tạo ra.
Vì vậy, nếu đầu vào là 11332, thì đầu ra sẽ là 31332
Để giải quyết vấn đề này, chúng tôi sẽ làm theo các bước sau -
-
li:=một danh sách theo các chữ số của n
-
đối với x trong phạm vi 0 đến kích thước của li - 1, thực hiện
-
nếu li [x] không phải là '3' thì
-
li [x]:='3'
-
trả lại số bằng cách hợp nhất các chữ số từ li
-
-
-
trả lại n
Hãy cùng chúng tôi xem cách triển khai sau để hiểu rõ hơn -
Ví dụ
class Solution: def solve(self, n): li = list(str(n)) for x in range(len(li)): if li[x] != '3': li[x] = '3' return int(''.join(li)) return n ob = Solution() print(ob.solve(11332))
Đầu vào
11332
Đầu ra
31332