Algorithm
(BOJ) 1759 풀이
snwo
2022. 3. 12. 15:21
package main
import (
"bufio"
"os"
"sort"
"strconv"
"strings"
)
var io = bufio.NewReadWriter(bufio.NewReader(os.Stdin),bufio.NewWriter(os.Stdout))
var L,C int
var ar []string
func back(k,c,v,prev int){
if k==L{
if c>1 && v>0{
for _,c :=range ar{
io.WriteString(c)
}
io.WriteByte('\n')
}
return
}
for i:=prev;i<C;i++{
ar[k]=numbers[i]
switch numbers[i]{
case
"a",
"e",
"i",
"o",
"u":
back(k+1,c,v+1,i+1)
default:
back(k+1,c+1,v,i+1)
}
}
}
var numbers[]string
func main(){
defer io.Flush()
bytes,_,_ :=io.ReadLine()
nums:=strings.Fields(string(bytes))
L,_=strconv.Atoi(nums[0])
C,_=strconv.Atoi(nums[1])
numbers=make([]string,C,C)
ar=make([]string,C,C)
bytes,_,_ = io.ReadLine()
numbers=strings.Fields(string(bytes))
sort.Strings(numbers)
back(0,0,0,0)
}
bufio 에 NewReadWriter 이 있길래, io 변수에 저장해서 변수 하나로 read, write 할 수 있게 짰다.
문자열을 정렬하고, ar 에 문자 하나씩 넣어서 백트래킹 한다.
함수 인자에 자음, 모음 갯수를 넣어줘서 k == L
일 때 최소조건을 만족하는지 검사하고 문자열을 출력해준다.
또한 백트래킹 함수를 호출한 시점의 i 값 +1
을 인자 prev 에 넘겨줘서
호출된 함수의 반복문이 numbers 의 prev 부터 참조해 ar 이 오름차순으로 정렬될 수 있게 한다.
(numbers 는 오름차순으로 정렬되어있음. 변수이름을 잘못지엇다)