| 
									
										
										
										
											2018-10-13 23:30:21 +03:00
										 |  |  | // Copyright © 2018 Inanc Gumus | 
					
						
							|  |  |  | // Learn Go Programming Course | 
					
						
							|  |  |  | // License: https://creativecommons.org/licenses/by-nc-sa/4.0/ | 
					
						
							|  |  |  | // | 
					
						
							| 
									
										
										
										
											2019-10-30 19:34:44 +03:00
										 |  |  | // For more tutorials  : https://learngoprogramming.com | 
					
						
							|  |  |  | // In-person training  : https://www.linkedin.com/in/inancgumus/ | 
					
						
							|  |  |  | // Follow me on twitter: https://twitter.com/inancgumus | 
					
						
							| 
									
										
										
										
											2018-10-13 23:30:21 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | package main | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"fmt" | 
					
						
							|  |  |  | 	"os" | 
					
						
							|  |  |  | 	"strings" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const corpus = "lazy cat jumps again and again and again" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func main() { | 
					
						
							|  |  |  | 	words := strings.Fields(corpus) | 
					
						
							|  |  |  | 	query := os.Args[1:] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | queries: | 
					
						
							|  |  |  | 	for _, q := range query { | 
					
						
							|  |  |  | 		// case insensitive search | 
					
						
							|  |  |  | 		q = strings.ToLower(q) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	search: | 
					
						
							|  |  |  | 		for i, w := range words { | 
					
						
							|  |  |  | 			switch q { | 
					
						
							|  |  |  | 			case "and", "or", "the": | 
					
						
							|  |  |  | 				break search | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if q == w { | 
					
						
							|  |  |  | 				fmt.Printf("#%-2d: %q\n", i+1, w) | 
					
						
							|  |  |  | 				continue queries | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |