mirror of
				https://github.com/golang/go.git
				synced 2025-10-31 16:50:58 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			52 lines
		
	
	
	
		
			849 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
	
		
			849 B
		
	
	
	
		
			Go
		
	
	
	
	
	
| // $G $F.go && $L $F.$A && ./$A.out
 | |
| 
 | |
| // Copyright 2009 The Go Authors. All rights reserved.
 | |
| // Use of this source code is governed by a BSD-style
 | |
| // license that can be found in the LICENSE file.
 | |
| 
 | |
| package main
 | |
| 
 | |
| // brainfuck
 | |
| 
 | |
| var p, pc int
 | |
| var a [30000]byte
 | |
| const prog = "++++++++++[>+++++++>++++++++++>+++>+<<<<-]>++.>+.+++++++..+++.>++.<<+++++++++++++++.>.+++.------.--------.>+.>.!"
 | |
| 
 | |
| func scan(dir int) {
 | |
| 	for nest := dir; dir*nest > 0; pc += dir {
 | |
| 		switch prog[pc+dir] {
 | |
| 			case ']':
 | |
| 				nest--
 | |
| 			case '[':
 | |
| 				nest++
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func main() {
 | |
| 	for {
 | |
| 		switch prog[pc] {
 | |
| 			case '>':
 | |
| 					p++
 | |
| 			case '<':
 | |
| 					p--
 | |
| 			case '+':
 | |
| 					a[p]++
 | |
| 			case '-':
 | |
| 					a[p]--
 | |
| 			case '.':
 | |
| 					print(string(a[p]))
 | |
| 			case '[':
 | |
| 				if a[p] == 0 {
 | |
| 					scan(1)
 | |
| 				}
 | |
| 			case ']':
 | |
| 				if a[p] != 0 {
 | |
| 					scan(-1)
 | |
| 				}
 | |
| 			default:
 | |
| 					return
 | |
| 		}
 | |
| 		pc++
 | |
| 	}
 | |
| }
 | 
