0

在文档和我能找到的所有示例中......至少在护士调度方面,每个人都只是在 {1,4} 的搜索空间内声明班次值,让我们说班次 1,2,3,4....

solver = pywrapcp.Solver("schedule_shifts")

  num_nurses = 4
  num_shifts = 4     # Nurse assigned to shift 0 means not working that day.
  num_days = 7
  # [START]
  # Create shift variables.
  shifts = {}

  for j in range(num_nurses):
    for i in range(num_days):
      shifts[(j, i)] = solver.IntVar(0, num_shifts - 1, "shifts(%i,%i)" % (j, i))
  shifts_flat = [shifts[(j, i)] for j in range(num_nurses) for i in range(num_days)]

  # Create nurse variables.
  nurses = {}

  for j in range(num_shifts):
    for i in range(num_days):
      nurses[(j, i)] = solver.IntVar(0, num_nurses - 1, "shift%d day%d" % (j,i))

我想在调用时避免使用值范围solver.IntVar(lowerbound, upperbound, ...)

我想IntSolver([available values that you can choose], ...)

我创建了一个包含所有班次的矩阵,作为从第一天到最后一天的列。我的行索引无关紧要,但在每一天/班次列中,我有护士的索引值,按该班次出价最高的降序排列。然后我想创建一个约束,如果我选择一名护士,我会选择通过列中的其他约束允许的最高出价,但是鉴于 python 的文档或工具有限,我不知道如何做到这一点IntVar

4

1 回答 1

0

你能试一下吗

solver.IntVar([values...], 'name')

它应该工作。

请参阅https://github.com/google/or-tools/blob/master/examples/python/einav_puzzle2.py

于 2018-06-21T08:11:36.763 回答