[프로그래머스] n진수 게임

2024. 9. 15. 22:33·PS/프로그래머스
반응형

문제

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

입력

진법 n, 미리 구할 숫자의 갯수 t, 게임에 참가하는 인원 m, 튜브의 순서 p 가 주어진다.

  • 2 ≦ n ≦ 16
  • 0 < t ≦ 1000
  • 2 ≦ m ≦ 100
  • 1 ≦ p ≦ m

출력

튜브가 말해야 하는 숫자 t개를 공백 없이 차례대로 나타낸 문자열. 단, 10~15는 각각 대문자 A~F로 출력한다.

 


해석

n진법으로 숫자를 변환한 후,  튜브가 말해야하는 마지막 차례까지 모든 숫자를 누적해서 저장한 다음 튜브가 말해야하는 문자들만 골라서 출력한다.

 

n진법으로 변환할 때는 String의 생성자를 이용한다.

public init<T>(_ value: T, radix: Int = 10, uppercase: Bool = false) where T : BinaryInteger

 


코드

import Foundation

extension String {
    subscript(_ index: Int) -> String {
        return String(self[self.index(self.startIndex, offsetBy: index)])
    }
}

func solution(_ n:Int, _ t:Int, _ m:Int, _ p:Int) -> String {
    
    var numbers: [String] = [] 
    
    var now: Int = 0 // 현재 숫자 
    
    var count: Int = 0 // 현재 담은 숫자 갯수 
    
    while count < t * m  {
        let number = String(now, radix:n, uppercase: true) // 진법 변환된 숫자
        numbers.append(number) 
        now += 1 // 다음 숫자 
        count += number.count // 해당 숫자만큼 길이 증가
    }
    
    var ans: [String] = []
    
    var index: Int = p-1
    
    let joinedNumbers = numbers.joined() // 문자열 
    
    while ans.count < t {
        ans.append(joinedNumbers[index])
        index += m
    }

    
    
    return ans.joined()
}
반응형

'PS > 프로그래머스' 카테고리의 다른 글

[프로그래머스] 괄호 변환  (1) 2024.09.17
[프로그래머스] 문자열 압축  (1) 2024.09.16
[프로그래머스] 오픈채팅방  (2) 2024.09.16
[프로그래머스] 파일명 정렬  (0) 2024.09.15
[프로그래머스] 압축  (0) 2024.09.15
'PS/프로그래머스' 카테고리의 다른 글
  • [프로그래머스] 문자열 압축
  • [프로그래머스] 오픈채팅방
  • [프로그래머스] 파일명 정렬
  • [프로그래머스] 압축
Hamp
Hamp
남들에게 보여주기 부끄러운 잡다한 글을 적어 나가는 자칭 기술 블로그입니다.
  • Hamp
    Hamp의 분리수거함
    Hamp
  • 전체
    오늘
    어제
    • 분류 전체보기 (304)
      • CS (30)
        • 객체지향 (2)
        • Network (7)
        • OS (6)
        • 자료구조 (1)
        • LiveStreaming (3)
        • 이미지 (1)
        • 잡다한 질문 정리 (0)
        • Hardware (2)
        • 이론 (6)
        • 컴퓨터 그래픽스 (0)
      • Firebase (3)
      • Programing Langauge (37)
        • swift (32)
        • python (4)
        • Kotlin (1)
      • iOS (132)
        • UIKit (37)
        • Combine (1)
        • SwiftUI (32)
        • Framework (7)
        • Swift Concurrency (22)
        • Tuist (6)
        • Setting (11)
        • Modularization (1)
        • Instruments (6)
      • PS (59)
        • 프로그래머스 (24)
        • 백준 (13)
        • LeetCode (19)
        • 알고리즘 (3)
      • Git (18)
        • 명령어 (4)
        • 이론 (2)
        • hooks (1)
        • config (2)
        • action (7)
      • Shell Script (2)
      • Linux (6)
        • 명령어 (5)
      • Spring (13)
        • 어노테이션 (1)
        • 튜토리얼 (11)
      • CI-CD (4)
      • Android (0)
        • Jetpack Compose (0)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    투포인터
    Swift
    UIKit
    AVFoundation
    CS
    IOS
    백준
    SwiftUI
    dp
    Spring
    concurrency
    dispatch
    GIT
    protocol
    property
    Tuist
    프로그래머스
    dfs
    boostcamp
    lifecycle
  • 최근 댓글

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
[프로그래머스] n진수 게임
상단으로

티스토리툴바