Submission #1089163

#TimeUsernameProblemLanguageResultExecution timeMemory
1089163vjudge1Bank (IZhO14_bank)Pypy 2
100 / 100
415 ms29508 KiB
def can_pay_all_salaries(N, M, salaries, banknotes): # Сортируем зарплаты и купюры в порядке убывания salaries.sort(reverse=True) banknotes.sort(reverse=True) used = [False] * M # Отслеживаем использованные купюры def backtrack(idx): if idx == N: return True # Все зарплаты выплачены current_salary = salaries[idx] # Функция для поиска подмножеств, суммирующихся в current_salary def dfs(start, total): if total == current_salary: # Если текущая зарплата выплачена, переходим к следующему сотруднику if backtrack(idx + 1): return True return False if total > current_salary: return False prev = -1 for i in range(start, M): if not used[i] and total + banknotes[i] <= current_salary: if banknotes[i] == prev: continue # Пропускаем одинаковые купюры для оптимизации used[i] = True if dfs(i + 1, total + banknotes[i]): return True used[i] = False prev = banknotes[i] return False return dfs(0, 0) return backtrack(0) # Чтение входных данных def main(): import sys import sys input = sys.stdin.read data = input().split() ptr = 0 N = int(data[ptr]) M = int(data[ptr +1]) ptr +=2 salaries = [] for _ in range(N): salaries.append(int(data[ptr])) ptr +=1 banknotes = [] for _ in range(M): banknotes.append(int(data[ptr])) ptr +=1 total_salary = sum(salaries) total_banknotes = sum(banknotes) if total_salary > total_banknotes: print("NO") return if can_pay_all_salaries(N, M, salaries, banknotes): print("YES") else: print("NO") if __name__ == "__main__": main()
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...