| 
									
										
										
										
											2018-11-15 16:37:09 +03:00
										 |  |  | // For more tutorials: https://blog.learngoprogramming.com | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // Copyright © 2018 Inanc Gumus | 
					
						
							|  |  |  | // Learn Go Programming Course | 
					
						
							|  |  |  | // License: https://creativecommons.org/licenses/by-nc-sa/4.0/ | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-13 17:43:25 +03:00
										 |  |  | package main | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"fmt" | 
					
						
							|  |  |  | 	"os" | 
					
						
							|  |  |  | 	"strconv" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const usage = `Sorry. Go arrays are fixed. | 
					
						
							|  |  |  | So, for now, I'm only supporting sorting %d numbers... | 
					
						
							|  |  |  | ` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func main() { | 
					
						
							|  |  |  | 	args := os.Args[1:] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	var nums [5]float64 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if len(args) > 5 { | 
					
						
							|  |  |  | 		fmt.Printf(usage, len(nums)) | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for i, v := range args { | 
					
						
							|  |  |  | 		n, err := strconv.ParseFloat(v, 64) | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			continue | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		nums[i] = n | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for range nums { | 
					
						
							|  |  |  | 		for i, v := range nums { | 
					
						
							|  |  |  | 			if i < len(nums)-1 && v > nums[i+1] { | 
					
						
							|  |  |  | 				nums[i], nums[i+1] = nums[i+1], nums[i] | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	fmt.Println(nums) | 
					
						
							|  |  |  | } |