Algorithm
(BOJ) 15666 풀이
snwo
2022. 3. 9. 11:37
package main
import (
"bufio"
"os"
"sort"
"strconv"
"strings"
)
var reader = bufio.NewReader(os.Stdin)
var writer = bufio.NewWriter(os.Stdout)
var N,M int
var ar,numbers []int
func back(k,prev int){
if k==M{
// fmt.Println(ar)
for i:=0;i<M;i++{
writer.WriteString(strconv.Itoa(ar[i])+" ")
}
writer.WriteByte(0xa)
return
}
temp:=-1
for i:=prev;i<N;i++{
if numbers[i] != temp{
ar[k]=numbers[i]
temp = numbers[i]
back(k+1,i)
}
}
}
func main(){
defer writer.Flush()
bytes,_,_ := reader.ReadLine()
nums:=strings.Fields(string(bytes))
N,_ = strconv.Atoi(nums[0])
M,_ = strconv.Atoi(nums[1])
bytes,_,_ = reader.ReadLine()
nums = strings.Fields(string(bytes))
ar=make([]int, M,10)
numbers=make([]int, N,10)
for i,v := range nums{
numbers[i],_=strconv.Atoi(v)
}
sort.Ints(numbers)
back(0,0)
}
N,M 그리고 정수를 N 개 입력받는다.
이 정수들로 수열을 만드는데 중복되지 않고 비내림차순이어야 한다.
back 함수는 인자로 k, prev
를 받는다
k 는 N 까지 ar 에 값을 채워넣는 인덱스 역할을 하고,
prev 는 비내림차순으로 ar 에 값을 넣기위해 이전 함수에서 호출한 시점의 i 값을 저장하고있다.
ex : 1 2 4 7 → 1 을 ar 에 넣으면 다음 ar 에 들어갈 수 있는 값은 idx = 0 부터 (비내림차순)
2 를 ar 에 넣으면 다음 ar 에 들어갈 수 있는 값은 idx = 1 부터 2,4,7
중복되는 수열을 없애기 위해 tmp
변수를 만들어서, ar[k]
에 들어갔던 값을 저장한 뒤
현재 numbers[i] 값과 다른지만 검사하면 된다.
[1,2,4,?,?,?] -> ar[2] 에 4(numbers[i])를 넣고 재귀호출해서 모든 수열을 구한다.
[1,2,4,?,?,?] -> 다음 수도 4(numbers[i+1]일 때, 재귀호출하면 중복되는 수열이 출력된다.
이를 막기위해 ar[k] 에 들어간 값을 tmp 에 저장한 뒤, 현재 numbers[i] 와 비교해서 걸러야한다.
입력받을 때 중복을 제거하는 방법도 있다.
go 언어로 짜면서 배운거
var reader = bufio.NewReader(os.Stdin)
var writer = bufio.NewWriter(os.Stdout)
이거 선언해서 입출력하면 좀 더 빨라진다.
reader 은 무조건 바이트배열로 받아서 []byte → string → int
이렇게 변환하면 된다.
writer 의 WriteString 메소드로 정수 출력할 때 int → string
바꿔줘야한다.
defer writer.Flush()
이거 메인함수에 안해주면 출력안됨 ㅅㄱ
sort 함수는 슬라이스를 대상으로 정렬해주기 때문에,
고정배열을 인자로 줄 수 없다.