|
| 1 | +tracer._print('original array = [' + D[0].join(', ') + ']'); |
| 2 | +tracer._sleep(1000); |
| 3 | +tracer._pace(300); |
| 4 | +function pow(base, expo){ |
| 5 | + var ans = 1; |
| 6 | + for(var i = 0; i < expo;i++){ |
| 7 | + ans *= base; |
| 8 | + } |
| 9 | + return ans; |
| 10 | +} |
| 11 | +for(var exp = 0; exp < 6;exp ++){ |
| 12 | + tracer._print("Bit "+exp); |
| 13 | + for(var i = 0; i < D[0].length; i++){ |
| 14 | + tracer._select(0, i); |
| 15 | + D[2][ parseInt( D[0][i] / pow(10, exp) % 10) ] += 1; |
| 16 | + tracer._notify(2, parseInt( D[0][i] / pow(10, exp) % 10) ); |
| 17 | + tracer._deselect(0, i); |
| 18 | + } |
| 19 | + for(var i = 1; i < 10; i++){ |
| 20 | + tracer._select(2, i - 1); |
| 21 | + D[2][i] += D[2][i - 1]; |
| 22 | + tracer._notify(2, i); |
| 23 | + tracer._deselect(2, i - 1); |
| 24 | + } |
| 25 | + for(var i = D[0].length - 1; i >= 0; i--){ |
| 26 | + tracer._select(0, i); |
| 27 | + D[2][parseInt( D[0][i] / pow(10, exp) % 10) ] -= 1; |
| 28 | + tracer._notify(2, parseInt( D[0][i] / pow(10, exp) % 10) ); |
| 29 | + D[1][ D[2][ parseInt( D[0][i] / pow(10, exp) % 10) ] ] = D[0][i]; |
| 30 | + tracer._notify(1, D[2][ parseInt( D[0][i] / pow(10, exp) % 10) ] ); |
| 31 | + tracer._deselect(0, i); |
| 32 | + } |
| 33 | + for(var i = 0; i < D[0].length; i++){ |
| 34 | + tracer._select(1, i); |
| 35 | + D[0][i] = D[1][i]; |
| 36 | + tracer._notify(0, i); |
| 37 | + tracer._deselect(1, i); |
| 38 | + } |
| 39 | + for(var i = 0; i < 10; i++){ |
| 40 | + D[2][i] = 0; |
| 41 | + tracer._notify(2, i); |
| 42 | + } |
| 43 | +} |
| 44 | +tracer._print('sorted array = [' + D[0].join(', ') + ']'); |
0 commit comments