This repository has been archived by the owner on Nov 11, 2023. It is now read-only.
/
coursematch.php
102 lines (86 loc) · 2.01 KB
/
coursematch.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
<?php
//include 'func/db.php';
//include 'func/generator.php';
function coursematch($courselist,$num,$darr, $conn){
if(empty($courselist)) return array();
$masterarr = array();
function addMaster($array, &$master){
//print_r($array);
$master[] = $array;
}
function check($con1, $con2){
foreach($con1 as $a){
foreach($con2 as $b){
if($a->conflictBool($b) && $a->sameDay($b)) return 0;
}
}
return 1;
}
//check using user preferences
//$time: 9,10,11,12
//days is an array in the style "M T W Th F S"
function checkPref($con1, $con2,$time,$days){
foreach ($con1 as $a) {
if(convertToMin($a->time_start)<$time*60){
return 0;
}
//checks required days with days in classes
foreach(str_split($a->days) as $day){
foreach(str_split($days) as $day2){
if($day == $day2) return 0;
}
}
}
foreach ($con2 as $b) {
if(convertToMin($b->time_start)<$time*60){
return 0;
}
//checks required days with days in classes
foreach(str_split($b->days) as $day){
foreach(str_split($days) as $day2){
if($day == $day2) return 0;
}
}
}
return 1;
}
$queue = array();
$index = 1;
$count = count($courselist);
$queue[] = generator($courselist[0], $conn);
$iterations=array(1);
while(!empty($queue)){
if($index < $count){
$curr = generator($courselist[$index],$conn);
$iterations[$index]=0;
for($a=0;$a<$iterations[$index-1];$a++){
foreach($queue[0] as $con1){
array_shift($queue);
foreach($curr as $con2){
if(check($con1,$con2) && checkPref($con1,$con2,$num,$darr)){
$newArr=array();
foreach($con1 as $elem1) { $newArr[] = $elem1; }
foreach($con2 as $elem2) { $newArr[] = $elem2; }
$newIteration = array($newArr);
$queue[]=$newIteration;
$iterations[$index]++;
}
}
}
}
}
else {
for($a=0;$a<$iterations[$index-1];$a++){
if(!empty($queue[0])){
addMaster($queue[0], $masterarr);
array_shift($queue);
}
}
}
$index++;
}
//print_r($masterarr);
return $masterarr;
}
//print_r(coursematch(array("CSCI-170"),0,"",$conn));
?>