TopCoder Problem:
http://www.topcoder.com/stat?c=problem_statement&pm=1585&rd=6535
Problem Statement |
| A busy businessman has a number of equally important tasks which he must accomplish. To decide which of the tasks to perform first, he performs the following operation. He writes down all his tasks in the form of a circular list, so the first task is adjacent to the last task. He then thinks of a positive number. This number is the random seed, which he calls n. Starting with the first task, he moves clockwise (from element 1 in the list to element 2 in the list and so on), counting from 1 to n. When his count reaches n, he removes that task from the list and starts counting from the next available task. He repeats this procedure until one task remains. It is this last task that he chooses to execute. Given a String[] list representing the tasks and an int n, return the task which the businessman chooses to execute. |
|
Definition |
| Class: | BusinessTasks | Method: | getTask | Parameters: | String[], int | Returns: | String | Method signature: | String getTask(String[] list, int n) | (be sure your method is public) |
|
|
|
|
Constraints |
- | list will contain between 2 and 50 elements inclusive. |
- | Each element in list will contain between 1 and 50 characters inclusive. |
- | Each element in list will contain only characters 'a'-'z'. |
- | n will be between 1 and 10000000 inclusive. |
|
Examples |
0) |
|
| | Returns: "a" | We start counting from a. So a is 1, b is 2. We remove b, so list is now {a,c,d}. We continue from c. So c is 1, d is 2. We remove d, so list is now {a,c}. We continue from a. So a is 1, c is 2. We remove c, and now we are left with the last task a. |
|
|
1) |
|
| | Returns: "d" | We start counting from a. So a is 1, b is 2, c is 3. We remove c, now list = {a,b,d,e}. We continue from d. So d is 1, e is 2, a is 3. We remove a, now list = {b,d,e}. We continue from b. So b is 1, d is 2, e is 3. We remove e, now list = {b,d}. We continue from b. So b is 1, d is 2 and finally b is 3. We remove b, and now we are left with just one task d. |
|
|
2) |
|
| {"alpha","beta","gamma","delta","epsilon"} | 1 |
| Returns: "epsilon" |
|
|
3) |
|
| |
4) |
|
| {"a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t", "u","v","w","x","y","z"} | 17 |
| Returns: "n" |
|
|
5) |
|
| {"zlqamum","yjsrpybmq","tjllfea","fxjqzznvg","nvhekxr","am","skmazcey","piklp", "olcqvhg","dnpo","bhcfc","y","h","fj","bjeoaxglt","oafduixsz","kmtbaxu", "qgcxjbfx","my","mlhy","bt","bo","q"} | 9000000 |
| Returns: "fxjqzznvg" |
|
My Solution:
import java.util.*;
public class BusinessTasks{
public String getTask(String[] list, int n){
List l = new ArrayList();
for (String a: list){
l.add(a);
}
int start =0;
while (l.size()!=1){
int index = start + n;
index = index % l.size();
if (index==0) {
index=l.size();
start=0;
} else {
start=index-1;
}
l.remove(index-1);
//System.out.println(l);
}
return l.get(0);
}
public static void main(String[] args){
BusinessTasks bt = new BusinessTasks();
System.out.println(bt.getTask(new String[]{"a","b","c","d"},2));
System.out.println(bt.getTask(new String[]{"a","b","c","d","e"},3));
System.out.println(bt.getTask(new String[]{"alpha","beta","gamma","delta","epsilon"},1));
System.out.println(bt.getTask(new String[]{"a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t",
"u","v","w","x","y","z"},17));
System.out.println(bt.getTask(new String[]{"zlqamum","yjsrpybmq","tjllfea","fxjqzznvg","nvhekxr","am","skmazcey","piklp",
"olcqvhg","dnpo","bhcfc","y","h","fj","bjeoaxglt","oafduixsz","kmtbaxu",
"qgcxjbfx","my","mlhy","bt","bo","q"},9000000));
}
}
No comments:
Post a Comment