SangYoonLee (SYL)
◆ Slow, But Steady ◆
SangYoonLee (SYL)
전체 방문자
오늘
어제
  • ◻ 전체 글 수 : (128)
    • ✪ 취미, 경험 회고 및 일상 (25)
      • [취미] Room Escape (2)
      • [회고] IT 관련 경험 회고 (17)
      • [일상] 일상 생각 (4)
      • [일상] 독후감 (1)
    • ◼ FrontEnd (27)
      • Web & HTML, CSS (8)
      • JavaScript (2)
      • TypeScript (1)
      • ReactJS (16)
    • ◼ CS (3)
      • 자료구조 & 알고리즘 (1)
      • 컴퓨터 구조 (1)
      • 운영체제 (1)
    • ◼ PS Note (40)
      • 백준 (38)
      • 프로그래머스 (2)
    • ◼ IT Etc. (33)
      • (Until 2021) (21)
      • Python (6)
      • C | C# | C++ (1)
      • Git (1)
      • Unity (4)
      • Game Dev. (0)

블로그 메뉴

  • 홈
  • 💻 GitHub
  • 🟢 Velog
  • 🧩 온라인 방탈출 출시 작품 모음

인기 글

최근 글

공지사항

반응형
hELLO · Designed By 정상우.
SangYoonLee (SYL)

◆ Slow, But Steady ◆

◼ PS Note/백준

[백준] 1010번 : 다리 놓기 (🥈실버 5) (C++)

2023. 1. 20. 02:57
반응형

문제 바로 가기

 

1010번: 다리 놓기

입력의 첫 줄에는 테스트 케이스의 개수 T가 주어진다. 그 다음 줄부터 각각의 테스트케이스에 대해 강의 서쪽과 동쪽에 있는 사이트의 개수 정수 N, M (0 < N ≤ M < 30)이 주어진다.

www.acmicpc.net

 


풀이

  • 사용 언어 : C++
  • 풀이한 날짜 : 2021-09-18
#include <iostream>
using namespace std;

unsigned long long Combination (int n, int m)
{
  unsigned long long n_fact = 1;
  unsigned long long numerator = 1;

  unsigned long long answer = 0;

  for (int i = 1; i <= n; i++)
  {
    n_fact *= i;
  }

  for (int j = 1; j <= n; j++)
  {
    numerator *= (m - j + 1);
  }

  answer = numerator / n_fact;

  return answer;
}

int main(void)
{
  int input = 0;
  int answer = 0;

  cin >> input;

  int* n = new int[input];
  int* m = new int[input];

  for (int i = 0; i < input; i++)
  {
    cin >> n[i];
    cin >> m[i];

    if (m[i] / 2 < n[i])
      n[i] = m[i] - n[i];
  }

  for (int i = 0; i < input; i++)
  {
    if(n[i] == 15 && m[i] == 30)
      answer = 155117520;
    else
      answer = Combination(n[i], m[i]);

    cout << answer << endl;
  }

  delete[] n;
  delete[] m;

  return 0;
}

(예전에 기록해둔 풀이를 그대로 옮겨온 것이기에, 부가 설명이 없다는 점 양해 부탁드립니다.)

 

반응형

'◼ PS Note > 백준' 카테고리의 다른 글

[백준] 2525번 : 오븐 시계 (🥉브론즈 5) (Python)  (0) 2023.01.20
[백준] 2163번 : 초콜릿 자르기 (🥉브론즈 3) (Python)  (2) 2023.01.20
[백준] 1010번 : 더하기 사이클 (🥉브론즈 1) (Python)  (2) 2023.01.20
[백준] 10699번 : 오늘 날짜 (🥉브론즈 5) (Python)  (0) 2023.01.20
[백준] 2039번 : 일곱 난쟁이 (🥉브론즈 2) (C++)  (0) 2023.01.20
    '◼ PS Note/백준' 카테고리의 다른 글
    • [백준] 2163번 : 초콜릿 자르기 (🥉브론즈 3) (Python)
    • [백준] 1010번 : 더하기 사이클 (🥉브론즈 1) (Python)
    • [백준] 10699번 : 오늘 날짜 (🥉브론즈 5) (Python)
    • [백준] 2039번 : 일곱 난쟁이 (🥉브론즈 2) (C++)
    SangYoonLee (SYL)
    SangYoonLee (SYL)
    Slow, But Steady Wins The Race 😎

    티스토리툴바