34 lines
		
	
	
		
			875 B
		
	
	
	
		
			Factor
		
	
	
			
		
		
	
	
			34 lines
		
	
	
		
			875 B
		
	
	
	
		
			Factor
		
	
	
| USING: arrays kernel math math.order random sequences
 | |
| tools.test ;
 | |
| IN: sorting.extras
 | |
| 
 | |
| { { 0 2 1 } } [ { 10 30 20 } [ <=> ] argsort ] unit-test
 | |
| { { 2 0 1 } } [
 | |
|     { "hello" "goodbye" "yo" } [ [ length ] bi@ <=> ] argsort
 | |
| ] unit-test
 | |
| 
 | |
| { { "blue" "green" "purple" } } [
 | |
|     { "green" "blue" "purple" } [ length ] map-sort
 | |
| ] unit-test
 | |
| { 1 { 1 2 3 4 } } [ 1 { 4 2 1 3 } [ dupd + ] map-sort ] unit-test
 | |
| 
 | |
| { 0 } [ 0 { 1 } bisect-right ] unit-test
 | |
| { 1 } [ 1 { 1 } bisect-right ] unit-test
 | |
| { 1 } [ 2 { 1 } bisect-right ] unit-test
 | |
| 
 | |
| { 0 } [ 0 { 1 } bisect-left ] unit-test
 | |
| { 0 } [ 1 { 1 } bisect-left ] unit-test
 | |
| { 1 } [ 2 { 1 } bisect-left ] unit-test
 | |
| 
 | |
| { { 0 1 2 3 4 5 6 7 8 9 } } [
 | |
|     { }
 | |
|     10 iota >array randomize
 | |
|     [ swap insort-right ] each
 | |
| ] unit-test
 | |
| 
 | |
| { V{ 0 1 2 3 4 5 6 7 8 9 } } [
 | |
|     V{ } clone
 | |
|     10 iota >array randomize
 | |
|     [ swap insort-right! ] each
 | |
| ] unit-test
 |