1 回答
TA贡献1869条经验 获得超4个赞
编辑:这有效吗?希望能有所帮助!
如果最多有 2 个专业,则会出现一个问题:有时并非所有学生都可以分配。
但它会尽可能地尝试,而且是随机的,所以如果它没有给出好的输出,就再试一次。
<?php
function shuffle_assoc($list) {
if (!is_array($list)) return $list;
$keys = array_keys($list);
shuffle($keys);
$random = array();
foreach ($keys as $key) {
$random[$key] = $list[$key];
}
return $random;
}
function searchForId($id, $array) {
foreach ($array as $key => $val) {
if ($val['specializations'] === $id) {
return $key;
}
}
return null;
}
$preferencesOfStudents = [
'students' => [
'Stacy' => ['Mr Jobs','Mr Gates','Mr Musk', 'Biology'],
'Carl' => ['Mr Jobs','Mr Gates','Mr Musk', 'Design'],
'Melody' => ['Mr Bezos','Mr Musk','Mr Gates', 'Usability'],
'William' => ['Mr Musk','Mr Gates','Mr Jobs', 'Computer Science'],
'Eric' => ['Mr Gates','Mr Jobs','Mr Musk', 'Physics'],
'Charlott' => ['Mr Jobs','Mr Gates','Mr Musk', 'Geography'],
'Anthony' => ['Mr Gates','Mr Musk','Mr Jobs', 'Geography'],
'Sarah' => ['Mr Gates','Mr Jobs','Mr Musk', 'Design'],
'Nelly' => ['Mr Gates','Mr Musk','Mr Jobs', 'Usability'],
'Connor' => ['Mr Gates','Mr Jobs','Mr Musk', 'Physics'],
'Frodo' => ['Mr Gates','Mr Musk','Mr Jobs', 'Computer Science'],
'Achmed' => ['Mr Gates','Mr Jobs','Mr Musk', 'Computer Science']
]
];
$teachers = [
'Mr Jobs' => [
'students' => [],
'specializations' => []
],
'Mr Gates' => [
'students' => [],
'specializations' => []
],
'Mr Musk' => [
'students' => [],
'specializations' => []
],
'Mr Bezos' => [
'students' => [],
'specializations' => []
]
];
$unassigned = [];
$randomStudentsArray = shuffle_assoc($preferencesOfStudents['students']);
/*assign students to prefered spots randomly*/
foreach($randomStudentsArray as $name => $student){
foreach ($teachers as $teacherName => $array) {
if (in_array($student[3],$array['specializations'])) {
$teachers[$teacherName]['students'][] = $name." (because of specialization) (".$student[3].")";
$teachers[$teacherName]['specializations'][] = $student[3];
break;
}
}
if(count($teachers[$student[0]]['students']) < 5 && count($teachers[$student[0]]['specializations']) < 2){
$teachers[$student[0]]['students'][] = $name." (first choice) (".$student[3].")";
$teachers[$student[0]]['specializations'][] = $student[3];
} elseif(count($teachers[$student[1]]['students']) < 5 && count($teachers[$student[1]]['specializations']) < 2) {
$teachers[$student[1]]['students'][] = $name." (second choice) (".$student[3].")";
$teachers[$student[1]]['specializations'][] = $student[3];
} elseif(count($teachers[$student[2]]['students']) < 5 && count($teachers[$student[2]]['specializations']) < 2) {
$teachers[$student[2]]['students'][] = $name." (third choice) (".$student[3].")";
$teachers[$student[2]]['specializations'][] = $student[3];
} else {
$unassigned[$name] = $student;
}
}
/*assign unassigned student to free spots*/
foreach($unassigned as $name => $student){
foreach($teachers as $teacherName => $listOfStudents){
if(count($listOfStudents['students']) < 5 && count($listOfStudents['specializations']) < 2){
$teachers[$teacherName]['students'][] = $name." (none of prefered choices) (".$student[3].")";
$teachers[$teacherName]['specializations'][] = $student[3];
}
}
}
print_r($teachers);
编辑2:
<?php
function shuffle_assoc($list) {
if (!is_array($list)) return $list;
$keys = array_keys($list);
shuffle($keys);
$random = array();
foreach ($keys as $key) {
$random[$key] = $list[$key];
}
return $random;
}
function searchForId($id, $array) {
foreach ($array as $key => $val) {
if ($val['specializations'] === $id) {
return $key;
}
}
return null;
}
$preferencesOfStudents = [
'students' => [
'Stacy' => ['Mr Jobs','Mr Gates','Mr Musk', 'Biology'],
'Carl' => ['Mr Jobs','Mr Gates','Mr Musk', 'Design'],
'Melody' => ['Mr Bezos','Mr Musk','Mr Gates', 'Usability'],
'William' => ['Mr Musk','Mr Gates','Mr Jobs', 'Computer Science'],
'Eric' => ['Mr Gates','Mr Jobs','Mr Musk', 'Physics'],
'Charlott' => ['Mr Jobs','Mr Gates','Mr Musk', 'Geography'],
'Anthony' => ['Mr Gates','Mr Musk','Mr Jobs', 'Geography'],
'Sarah' => ['Mr Gates','Mr Jobs','Mr Musk', 'Design'],
'Nelly' => ['Mr Gates','Mr Musk','Mr Jobs', 'Usability'],
'Connor' => ['Mr Gates','Mr Jobs','Mr Musk', 'Physics'],
'Frodo' => ['Mr Gates','Mr Musk','Mr Jobs', 'Computer Science'],
'Achmed' => ['Mr Gates','Mr Jobs','Mr Musk', 'Computer Science']
]
];
$teachers = [
'Mr Jobs' => [
'students' => [],
'specializations' => ['Biology', 'Design']
],
'Mr Gates' => [
'students' => [],
'specializations' => ['Computer Science', 'Usability']
],
'Mr Musk' => [
'students' => [],
'specializations' => ['Physics', 'Geography']
],
'Mr Bezos' => [
'students' => [],
'specializations' => ['Usability', 'Biology']
]
];
$unassigned = [];
$randomStudentsArray = shuffle_assoc($preferencesOfStudents['students']);
/*assign students to prefered spots randomly*/
foreach($randomStudentsArray as $name => $student){
if(count($teachers[$student[0]]['students']) < 5 && in_array($student[3],$teachers[$student[0]]['specializations'])){
$teachers[$student[0]]['students'][] = $name." (first choice) (".$student[3].")";
} elseif(count($teachers[$student[1]]['students']) < 5 && in_array($student[3],$teachers[$student[1]]['specializations'])) {
$teachers[$student[1]]['students'][] = $name." (second choice) (".$student[3].")";
} elseif(count($teachers[$student[2]]['students']) < 5 && in_array($student[3],$teachers[$student[2]]['specializations'])) {
$teachers[$student[2]]['students'][] = $name." (third choice) (".$student[3].")";
} else {
$unassigned[$name] = $student;
}
}
/*assign unassigned student to free spots*/
foreach($unassigned as $name => $student){
foreach($teachers as $teacherName => $listOfStudents){
if(count($listOfStudents['students']) < 5 && count($listOfStudents['specializations']) < 2 && in_array($student[3],$teachers[$teacherName]['specializations'])){
$teachers[$teacherName]['students'][] = $name." (none of prefered choices) (".$student[3].")";
}
}
}
print_r($teachers);
编辑3:
<?php
function shuffle_assoc($list) {
if (!is_array($list)) return $list;
$keys = array_keys($list);
shuffle($keys);
$random = array();
foreach ($keys as $key) {
$random[$key] = $list[$key];
}
return $random;
}
function searchForId($id, $array) {
foreach ($array as $key => $val) {
if ($val['specializations'] === $id) {
return $key;
}
}
return null;
}
$preferencesOfStudents = [
'students' => [
'Stacy' => ['Mr Jobs','Mr Gates','Mr Musk', 'Biology', 'Usability'],
'Carl' => ['Mr Jobs','Mr Gates','Mr Musk', 'Design', 'Physics'],
'Melody' => ['Mr Bezos','Mr Musk','Mr Gates', 'Usability', 'Physics'],
'William' => ['Mr Musk','Mr Gates','Mr Jobs', 'Computer Science', 'Usability'],
'Eric' => ['Mr Gates','Mr Jobs','Mr Musk', 'Physics', 'Design'],
'Charlott' => ['Mr Bezos','Mr Gates','Mr Musk', 'Geography', 'Design'],
'Anthony' => ['Mr Gates','Mr Musk','Mr Jobs', 'Geography', 'Computer Science'],
'Sarah' => ['Mr Bezos','Mr Jobs','Mr Musk', 'Design', 'Physics'],
'Nelly' => ['Mr Gates','Mr Musk','Mr Jobs', 'Usability', 'Design'],
'Connor' => ['Mr Gates','Mr Bezos','Mr Musk', 'Physics', 'Usability'],
'Frodo' => ['Mr Gates','Mr Musk','Mr Jobs', 'Computer Science', 'Geography'],
'Achmed' => ['Mr Gates','Mr Jobs','Mr Musk', 'Computer Science', 'Geography'],
'Charlie' => ['Mr Bezos','Mr Musk','Mr Gates', 'Usability', 'Physics'],
'India' => ['Mr Musk','Mr Gates','Mr Jobs', 'Computer Science', 'Usability'],
'Lima' => ['Mr Gates','Mr Jobs','Mr Musk', 'Physics', 'Design'],
'Mike' => ['Mr Jobs','Mr Gates','Mr Musk', 'Geography', 'Design'],
'Oscar' => ['Mr Gates','Mr Musk','Mr Jobs', 'Usability', 'Computer Science'],
'Quentin' => ['Mr Gates','Mr Jobs','Mr Musk', 'Design', 'Physics'],
'Sam' => ['Mr Gates','Mr Musk','Mr Jobs', 'Usability', 'Design'],
'Victor' => ['Mr Gates','Mr Jobs','Mr Musk', 'Physics', 'Usability'],
'Zach' => ['Mr Gates','Mr Musk','Mr Jobs', 'Computer Science', 'Geography'],
'Arya' => ['Mr Gates','Mr Jobs','Mr Musk', 'Computer Science', 'Geography']
]
];
$teachers = [
'Mr Jobs' => [
'students' => [],
'specializations' => ['Biology', 'Design']
],
'Mr Gates' => [
'students' => [],
'specializations' => ['Computer Science', 'Usability']
],
'Mr Musk' => [
'students' => [],
'specializations' => ['Physics', 'Geography']
],
'Mr Bezos' => [
'students' => [],
'specializations' => ['Usability', 'Biology']
]
];
$unassigned = [];
$randomStudentsArray = shuffle_assoc($preferencesOfStudents['students']);
/*assign students to prefered spots randomly*/
foreach($randomStudentsArray as $name => $student){
if(count($teachers[$student[0]]['students']) < 5 && (in_array($student[3],$teachers[$student[0]]['specializations']) || in_array($student[3],$teachers[$student[0]]['specializations']))){
$teachers[$student[0]]['students'][] = $name." (first choice) (".$student[3].")";
} elseif(count($teachers[$student[1]]['students']) < 5 && (in_array($student[3],$teachers[$student[1]]['specializations']) || in_array($student[3],$teachers[$student[0]]['specializations']))) {
$teachers[$student[1]]['students'][] = $name." (second choice) (".$student[3].")";
} elseif(count($teachers[$student[2]]['students']) < 5 && (in_array($student[3],$teachers[$student[2]]['specializations']) || in_array($student[3],$teachers[$student[0]]['specializations']))) {
$teachers[$student[2]]['students'][] = $name." (third choice) (".$student[3].")";
} else {
$unassigned[$name] = $student;
}
}
/*assign unassigned student to free spots*/
foreach($unassigned as $name => $student){
foreach($teachers as $teacherName => $listOfStudents){
if(count($listOfStudents['students']) < 5 && count($listOfStudents['specializations']) < 2 && ( in_array($student[3],$teachers[$teacherName]['specializations']) || in_array($student[4],$teachers[$teacherName]['specializations']) )){
$teachers[$teacherName]['students'][] = $name." (none of prefered choices) (".$student[3].")";
}
}
}
print_r($teachers);
- 1 回答
- 0 关注
- 102 浏览
添加回答
举报