// The following implementation assumes that the activities
// are already sorted according to their finish time
import java.util.*;
import java.lang.*;
import java.io.*;
class ActivitySelection
{
// Prints a maximum set of activities that can be done by a single
// person, one at a time.
// n --> Total number of activities
// s[] --> An array that contains start time of all activities
// f[] --> An array that contains finish time of all activities
public static void printMaxActivities(int s[], int f[], int n)
{
int i, j;
System.
out.
print("Following activities are selected : n");
// The first activity always gets selected
i = 0;
// Consider rest of the activities
for (j = 1; j < n; j++)
{
// If this activity has start time greater than or
// equal to the finish time of previously selected
// activity, then select it
if (s[j] >= f[i])
{
i = j;
}
}
}
// driver program to test above function
public static void main
(String[] args
) {
int s[] = {1, 3, 0, 5, 8, 5};
int f[] = {2, 4, 6, 7, 9, 9};
int n = s.length;
printMaxActivities(s, f, n);
}
}
Ly8gVGhlIGZvbGxvd2luZyBpbXBsZW1lbnRhdGlvbiBhc3N1bWVzIHRoYXQgdGhlIGFjdGl2aXRpZXMgCi8vIGFyZSBhbHJlYWR5IHNvcnRlZCBhY2NvcmRpbmcgdG8gdGhlaXIgZmluaXNoIHRpbWUgCmltcG9ydCBqYXZhLnV0aWwuKjsgCmltcG9ydCBqYXZhLmxhbmcuKjsgCmltcG9ydCBqYXZhLmlvLio7IAoKY2xhc3MgQWN0aXZpdHlTZWxlY3Rpb24gCnsgCgkvLyBQcmludHMgYSBtYXhpbXVtIHNldCBvZiBhY3Rpdml0aWVzIHRoYXQgY2FuIGJlIGRvbmUgYnkgYSBzaW5nbGUgCgkvLyBwZXJzb24sIG9uZSBhdCBhIHRpbWUuIAoJLy8gbiAtLT4gVG90YWwgbnVtYmVyIG9mIGFjdGl2aXRpZXMgCgkvLyBzW10gLS0+IEFuIGFycmF5IHRoYXQgY29udGFpbnMgc3RhcnQgdGltZSBvZiBhbGwgYWN0aXZpdGllcyAKCS8vIGZbXSAtLT4gQW4gYXJyYXkgdGhhdCBjb250YWlucyBmaW5pc2ggdGltZSBvZiBhbGwgYWN0aXZpdGllcyAKCXB1YmxpYyBzdGF0aWMgdm9pZCBwcmludE1heEFjdGl2aXRpZXMoaW50IHNbXSwgaW50IGZbXSwgaW50IG4pIAoJeyAKCWludCBpLCBqOyAKCQoJU3lzdGVtLm91dC5wcmludCgiRm9sbG93aW5nIGFjdGl2aXRpZXMgYXJlIHNlbGVjdGVkIDogbiIpOyAKCQoJLy8gVGhlIGZpcnN0IGFjdGl2aXR5IGFsd2F5cyBnZXRzIHNlbGVjdGVkIAoJaSA9IDA7IAoJU3lzdGVtLm91dC5wcmludChpKyIgIik7IAoJCgkvLyBDb25zaWRlciByZXN0IG9mIHRoZSBhY3Rpdml0aWVzIAoJZm9yIChqID0gMTsgaiA8IG47IGorKykgCgl7IAoJCS8vIElmIHRoaXMgYWN0aXZpdHkgaGFzIHN0YXJ0IHRpbWUgZ3JlYXRlciB0aGFuIG9yIAoJCS8vIGVxdWFsIHRvIHRoZSBmaW5pc2ggdGltZSBvZiBwcmV2aW91c2x5IHNlbGVjdGVkIAoJCS8vIGFjdGl2aXR5LCB0aGVuIHNlbGVjdCBpdCAKCQlpZiAoc1tqXSA+PSBmW2ldKSAKCQl7IAoJCQlTeXN0ZW0ub3V0LnByaW50KGorIiAiKTsgCgkJCWkgPSBqOyAKCQl9IAoJfSAKCX0gCgkKCS8vIGRyaXZlciBwcm9ncmFtIHRvIHRlc3QgYWJvdmUgZnVuY3Rpb24gCglwdWJsaWMgc3RhdGljIHZvaWQgbWFpbihTdHJpbmdbXSBhcmdzKSAKCXsgCglpbnQgc1tdID0gezEsIDMsIDAsIDUsIDgsIDV9OyAKCWludCBmW10gPSB7MiwgNCwgNiwgNywgOSwgOX07IAoJaW50IG4gPSBzLmxlbmd0aDsgCgkJCglwcmludE1heEFjdGl2aXRpZXMocywgZiwgbik7IAoJfSAKCQp9IAo=