University stuff.
Du kannst nicht mehr als 25 Themen auswählen Themen müssen mit entweder einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

Parallel.java 1.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. class Parallel implements Solver {
  2. class Worker implements Runnable {
  3. MultiRadix mr;
  4. int[] arr;
  5. int start, end;
  6. boolean done = false;
  7. Worker( int[] arr, int start, int end) {
  8. this.arr = new int[end - start];
  9. int j = 0;
  10. for (int i = start; i < end; ++i) {
  11. this.arr[j++] = arr[i];
  12. }
  13. }
  14. synchronized public void run() {
  15. arr = new MultiRadix().radixMulti(arr);
  16. done = true;
  17. notify();
  18. }
  19. synchronized public void waitFor() {
  20. while (!done) {
  21. try { wait(); } catch (InterruptedException ex) {}
  22. }
  23. }
  24. }
  25. public int[] sort(int[] arr) {
  26. int n = 2;
  27. int d = arr.length / n;
  28. Worker[] workers = new Worker[n];
  29. Thread[] threads = new Thread[n];
  30. for (int i = 0; i < n; ++i) {
  31. int start = d * i;
  32. int end;
  33. if (i == n - 1)
  34. end = arr.length;
  35. else
  36. end = d * (i + 1);
  37. Worker w; Thread t;
  38. workers[i] = w = new Worker(arr, start, end);
  39. threads[i] = t = new Thread(w);
  40. t.start();
  41. }
  42. for (int i = 0; i < n; ++i) {
  43. workers[i].waitFor();
  44. try {
  45. threads[i].join();
  46. } catch (InterruptedException ex) {}
  47. }
  48. int[] is = new int[n];
  49. for (int i = 0; i < n; ++i)
  50. is[i] = 0;
  51. for (int i = 0; i < arr.length; ++i) {
  52. int biggest = Integer.MAX_VALUE;
  53. int biggestJ = 0;
  54. Worker biggestW = null;
  55. for (int j = 0; j < n; ++j) {
  56. Worker w = workers[j];
  57. if (is[j] >= w.arr.length)
  58. continue;
  59. int num = w.arr[is[j]];
  60. if (num <= biggest) {
  61. biggest = num;
  62. biggestJ = j;
  63. biggestW = w;
  64. }
  65. }
  66. arr[i] = biggestW.arr[is[biggestJ]++];
  67. }
  68. return arr;
  69. }
  70. }