그래서 key : value (tuple)가있는 사전이 있습니다. 이 같은. { "name":(4,5), ....} 여기서 (4,5)는 두 개의 카테고리 (cat1, cat2)를 나타냅니다. 두 번째 범주의 최대 개수를 감안할 때 첫 번째 범주가 최대화되거나 최소화되도록 사전 항목의 최적 조합을 찾고 싶습니다.사전에서 최적의 그룹 선택 Python
예를 들어, maxCat2 = 15 인 경우, 각 항목의 cat2 값을 함께 추가 할 때 사전에서 항목 조합을 찾고 싶습니다. 15 세 미만입니다. 많은 조건이있을 수 있습니다. 이러한 가능성 중에서도 각 항목에 대해 cat1 값을 추가 할 때 다른 항목보다 더 큰 항목을 선택하고 싶습니다.
사전에 항목의 모든 순열을 얻은 다음 각 항목이 maxCat2 기준을 충족시키는 지 확인한 다음 가장 큰 총 cat1 값을 제공하는 알고리즘을 확인하는 알고리즘을 작성했습니다. 20 개의 항목이 있다면 20 개를 확인합니다. 콤비네이션은 매우 큰 숫자입니다. 이 문제를 피하기 위해 제가 할 수있는 일이 있습니까? 감사.
그래서 ... 많은 ... 텍스트! 형식을 지정하고 예를 들면 많은 사람들이 그것을 읽게됩니다 (범죄는 없습니다). – Blender
http://en.wikipedia.org/wiki/Knapsack_problem –
지금까지 무엇을 시도했지만 무엇이 효과가 있습니까? 포스트 코드 또는 그것은 일어나지 않았다! – jathanism