Algoritmo para el Cifrado Cesar en Go, común cuando inicias en criptografía y fácil de implementar, solo que en momentos de presión puedes llegar a hacer algo complicado cuando en realidad lo puedes resolver con un poco de aritmética (simple).
package main
import "fmt"
func main() {
alphabet := []string{"a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "ñ", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z"}
shift := 3
out := make([]string, len(alphabet))
for i, v := range alphabet {
newIndex := (i + shift) % len(alphabet)
out[newIndex] = v
}
fmt.Println("Original:", alphabet)
fmt.Println("Cifrado :", out)
}
// Incluyendo la ñ en el alfabeto español
// Usamos módulo para que al llegar al final vuelva al inicio