문제

땅 위에 달팽이가 있다. 이 달팽이는 높이가 V미터인 나무 막대를 올라갈 것이다.

달팽이는 낮에 A미터 올라갈 수 있다. 하지만, 밤에 잠을 자는 동안 B미터 미끄러진다. 또, 정상에 올라간 후에는 미끄러지지 않는다.

달팽이가 나무 막대를 모두 올라가려면, 며칠이 걸리는지 구하는 프로그램을 작성하시오.


입력

첫째 줄에 세 정수 A, B, V가 공백으로 구분되어서 주어진다. (1 ≤ B < A ≤ V ≤ 1,000,000,000)


출력

첫째 줄에 달팽이가 나무 막대를 모두 올라가는데 며칠이 걸리는지 출력한다.


코드

using System;
					
public class Program
{
	public static void Main()
	{
		// :: [설계]
		// :: (올라가는 거리, 떨어지는 거리, 총 거리)를 한 줄로, ' ' 구분으로 입력 받는다.
		
		// :: 총 거리에서 마지막에 떨어지지 않는 거리만큼 뺀다.
		// :: 하루에 올라가는 거리(올라가는 거리 - 떨어지는 거리)를 구한다.
		
		// :: 총 거리 / 하루에 올라가는 거리로 날짜를 구한다.
		// :: 만약 총 거리 % 하루에 올라가는 거리가 나머지가 있으면, 날짜를 하루 더 더해준다.
		
		// :: 출력한다.
		
		// :: [구현]
		// :: (올라가는 거리, 떨어지는 거리, 총 거리)를 한 줄로, ' ' 구분으로 입력 받는다.
		string[] inputRaw = Console.ReadLine().Split(' ');
		int climbDistance = int.Parse(inputRaw[0]);
		int fallDistance = int.Parse(inputRaw[1]);
		int goalDistance = int.Parse(inputRaw[2]);
		
		// :: 총 거리에서 마지막에 떨어지지 않는 거리만큼 뺀다.
		goalDistance -= fallDistance;
		
		// :: 하루에 올라가는 거리(올라가는 거리 - 떨어지는 거리)를 구한다.
		int dailyDistance = climbDistance - fallDistance;
		
		// :: 총 거리 / 하루에 올라가는 거리로 날짜를 구한다.
		int days = goalDistance / dailyDistance;
		
		// :: 만약 총 거리 % 하루에 올라가는 거리가 나머지가 있으면, 날짜를 하루 더 더해준다.
		if((goalDistance % dailyDistance) != 0) {
			days += 1;
		}
		
		// :: 출력한다.
		Console.WriteLine(days);
	}
}

 

블로그 이미지

RIsN

,

문제

1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.

  1. 같은 눈이 3개가 나오면 10,000원+(같은 눈)×1,000원의 상금을 받게 된다. 
  2. 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈)×100원의 상금을 받게 된다. 
  3. 모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)×100원의 상금을 받게 된다.  

예를 들어, 3개의 눈 3, 3, 6이 주어지면 상금은 1,000+3×100으로 계산되어 1,300원을 받게 된다. 또 3개의 눈이 2, 2, 2로 주어지면 10,000+2×1,000 으로 계산되어 12,000원을 받게 된다. 3개의 눈이 6, 2, 5로 주어지면 그중 가장 큰 값이 6이므로 6×100으로 계산되어 600원을 상금으로 받게 된다.

3개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성 하시오.


입력

첫째 줄에 3개의 눈이 빈칸을 사이에 두고 각각 주어진다. 


출력

첫째 줄에 게임의 상금을 출력 한다.


코드

using System;
using System.Collections.Generic;
					
public class Program
{
	public static void Main()
	{
		// :: [설계]
		// :: 3개의 주사위 숫자를 한 줄로, ' ' 구분으로 입력 받는다.
		// :: Dictionary<int, int>로 주사위 숫자를 key에 넣는다.
			// :: 키가 아직 없으면 value = 1
			// :: 키가 있으면 value += 1
			// :: 가장 큰 주사위 숫자를 저장한다.
			// :: 가장 큰 value 숫자를 저장한다.
				// :: +1 될 때의 동일 주사위 숫자를 저장한다.
		
		// :: 가장 큰 value를 기준으로 연산 처리한다.
		// :: If 1
			// :: 가장 큰 주사위 숫자 * 100
		// :: If 2
			// :: 동일 주사위 숫자 * 100 + 1000
		// :: If 3
			// :: 동일 주사위 숫자 * 1000 + 10000
		
		// :: 위의 값을 출력한다
		
		string[] diceRaws = Console.ReadLine().Split(' ');
		
		Dictionary<int, int> diceResult = new Dictionary<int, int>();
		int maxDice = 0;
		int sameDice = 0;
		int sameDiceCount = 1;
		
		for(int index = 0; index < diceRaws.Length; index++) {
			int dice = int.Parse(diceRaws[index]);
			
			if(diceResult.ContainsKey(dice)) {
				diceResult[dice] += 1;
				
				sameDice = dice;
				sameDiceCount = diceResult[dice];
			} else {
				diceResult.Add(dice, 1);
				
				if(maxDice < dice) {
					maxDice = dice;
				}
			}
		}
		
		int value = 0;
		if(sameDiceCount == 1) {
			value = maxDice * 100;
		} else if(sameDiceCount == 2) {
			value = 1000 + (sameDice * 100);
		} else if(sameDiceCount == 3) {
			value = 10000 + (1000 * sameDice);
		}
		
		Console.WriteLine(value);
	}
}

 

'C# > Baekjoon' 카테고리의 다른 글

백준 10250 : ACM 호텔  (0) 2022.03.17
백준 2869 : 달팽이는 올라가고 싶다  (0) 2022.03.13
백준 2525 : 오븐 시계  (0) 2022.03.09
백준 18108 : 1998년생인 내가 태국에서는 2541년생?!  (0) 2022.03.07
백준 10926 : ??!  (0) 2022.03.06
블로그 이미지

RIsN

,

문제

KOI 전자에서는 건강에 좋고 맛있는 훈제오리구이 요리를 간편하게 만드는 인공지능 오븐을 개발하려고 한다. 인공지능 오븐을 사용하는 방법은 적당한 양의 오리 훈제 재료를 인공지능 오븐에 넣으면 된다. 그러면 인공지능 오븐은 오븐구이가 끝나는 시간을 분 단위로 자동적으로 계산한다.

또한, KOI 전자의 인공지능 오븐 앞면에는 사용자에게 훈제오리구이 요리가 끝나는 시각을 알려 주는 디지털 시계가 있다. 

훈제오리구이를 시작하는 시각과 오븐구이를 하는 데 필요한 시간이 분단위로 주어졌을 때, 오븐구이가 끝나는 시각을 계산하는 프로그램을 작성하시오.


입력

첫째 줄에는 현재 시각이 나온다. 현재 시각은 시 A (0 ≤ A ≤ 23) 와 분 B (0 ≤ B ≤ 59)가 정수로 빈칸을 사이에 두고 순서대로 주어진다. 두 번째 줄에는 요리하는 데 필요한 시간 C (0 ≤ C ≤ 1,000)가 분 단위로 주어진다. 


출력

첫째 줄에 종료되는 시각의 시와 분을 공백을 사이에 두고 출력한다. (단, 시는 0부터 23까지의 정수, 분은 0부터 59까지의 정수이다. 디지털 시계는 23시 59분에서 1분이 지나면 0시 0분이 된다.)


코드

using System;
					
public class Program
{
	public static void Main()
	{
		// :: 기준 시간 가져오기
		string[] time = Console.ReadLine().Split(' ');
		
		// :: 기준 시간 나누기
		int hour = int.Parse(time[0]);
		int minute = int.Parse(time[1]);
		
		// :: 추가 시간 더하기
		minute += int.Parse(Console.ReadLine());
		
		// :: 고정 시간
		const int staticHour = 60;
		const int staticDay = 24;
		
		// :: 시간 계산
		if(minute >= staticHour) {
			// :: 시 계산
			hour += (minute / staticHour);
			if(hour >= staticDay) {
				hour -= staticDay;
			}
			
			// :: 분 계산
			minute = minute % staticHour;
		}
		
		// :: 출력
		Console.WriteLine(string.Format("{0} {1}", hour, minute));
	}
}

 

'C# > Baekjoon' 카테고리의 다른 글

백준 10250 : ACM 호텔  (0) 2022.03.17
백준 2869 : 달팽이는 올라가고 싶다  (0) 2022.03.13
백준 2480 : 주사위 세개  (0) 2022.03.12
백준 18108 : 1998년생인 내가 태국에서는 2541년생?!  (0) 2022.03.07
백준 10926 : ??!  (0) 2022.03.06
블로그 이미지

RIsN

,

문제

ICPC Bangkok Regional에 참가하기 위해 수완나품 국제공항에 막 도착한 팀 레드시프트 일행은 눈을 믿을 수 없었다. 공항의 대형 스크린에 올해가 2562년이라고 적혀 있던 것이었다.

불교 국가인 태국은 불멸기원(佛滅紀元), 즉 석가모니가 열반한 해를 기준으로 연도를 세는 불기를 사용한다. 반면, 우리나라는 서기 연도를 사용하고 있다. 불기 연도가 주어질 때 이를 서기 연도로 바꿔 주는 프로그램을 작성하시오.


입력

서기 연도를 알아보고 싶은 불기 연도 y가 주어진다. (1000 ≤ y ≤ 3000)


출력

불기 연도를 서기 연도로 변환한 결과를 출력한다.


코드

using System;

public class HelloWorld
{
    public static void Main(string[] args)
    {
        int diff = 544 - 1;
        Console.WriteLine(int.Parse(Console.ReadLine()) - diff);
    }
}

설명

  1. 불기, 서기 차이 확인해서 : int diff = 544 - 1
  2. 읽은 걸 : Console.ReadLine()
  3. 숫자로 변환하고 : int.Parse()
  4. 차이 만큼 빼서 : - diff
  5. 출력한다 : Console.WriteLine()

'C# > Baekjoon' 카테고리의 다른 글

백준 10250 : ACM 호텔  (0) 2022.03.17
백준 2869 : 달팽이는 올라가고 싶다  (0) 2022.03.13
백준 2480 : 주사위 세개  (0) 2022.03.12
백준 2525 : 오븐 시계  (0) 2022.03.09
백준 10926 : ??!  (0) 2022.03.06
블로그 이미지

RIsN

,

백준 10926 : ??!

C#/Baekjoon 2022. 3. 6. 12:01

문제

준하는 사이트에 회원가입을 하다가 joonas라는 아이디가 이미 존재하는 것을 보고 놀랐다. 준하는 놀람을 ??!로 표현한다. 준하가 가입하려고 하는 사이트에 이미 존재하는 아이디가 주어졌을 때, 놀람을 표현하는 프로그램을 작성하시오.


입력

첫째 줄에 준하가 가입하려고 하는 사이트에 이미 존재하는 아이디가 주어진다. 아이디는 알파벳 소문자로만 이루어져 있으며, 길이는 50자를 넘지 않는다.


출력

첫째 줄에 준하의 놀람을 출력한다. 놀람은 아이디 뒤에 ??!를 붙여서 나타낸다.


코드

using System;
					
public class Program
{
	public static void Main()
	{
		Console.WriteLine(Console.ReadLine() + "??!");
	}
}

설명

  1. 받아서 : Console.ReadLine()
  2. 추가해서 : + "??!"
  3. 출력한다 : Console.WriteLine(출력 문자)
블로그 이미지

RIsN

,

관찰자 패턴이란?

준비중...

왜 썼는가?

현재 제작중인 게임(Summerfield / Tamago)에서
> 매 분마다 처리를 하는 것은 최종 관리자 스크립트(Dictator)의 역할로
> 다른 스크립트들은 그 때마다 보여주는 것만 업데이트하는 설계로 되어 있음

따라서 매분 처리가 발생할 때마다 다른 스크립트가 관찰을 해서,
자신의 UI나 게임오브젝트를 업데이트 하도록 사용

인터페이스 구성

public interface ISubject
{
    void RegisterObserver(IObserver observer);
    void RemoveObserver(IObserver observer);
    void NotifyObservers_Minute();
}

public interface IObserver
{
    void UpdateMinute();
}

'Programming > Pattern' 카테고리의 다른 글

싱글톤 패턴(Singleton Pattern) with Unity  (0) 2021.03.15
블로그 이미지

RIsN

,

백준 1193 : 분수찾기

C# 2021. 2. 3. 23:24

무한히 큰 배열에 다음과 같이 분수들이 적혀있다.

1/1 1/2 1/3 1/4 1/5
2/1 2/2 2/3 2/4
3/1 3/2 3/3
4/1 4/2
5/1

이와 같이 나열된 분수들을 1/1 -> 1/2 -> 2/1 -> 3/1 -> 2/2 -> … 과 같은 지그재그 순서로 차례대로 1번, 2번, 3번, 4번, 5번, … 분수라고 하자.

X가 주어졌을 때, X번째 분수를 구하는 프로그램을 작성하시오.

첫째 줄에 X(1 ≤ X ≤ 10,000,000)가 주어진다.
첫째 줄에 분수를 출력한다.

:: 성공

 

: 설명 :

> 속도가 중요함 = 공식을 써서 풀라는 것...

 

> 각 단계마다 +1씩 개수들이 증가한다.

>> 1단계(1/1) 2단계(1/2, 2/1) 3단계(3/1, 2/2, 1/3)

 

> 그러니 우선 받은 숫자가 몇 단계 다음인지를 확인한다.

>> 14의 경우 5단계 다음에 온다.

 

> 그 후 다음 단계 가장 처음에 오는 숫자의 번째를 확인(5단계 다음 시작은 11번째부터).

> 지금 받은 숫자가 5단계 다음 시작해서 몇 번째에 오는지 확인(11번째부터 14번째까지니까 6단계 시작해서 4번째, 차이는 3)

> 그 다음은 홀수 짝수를 구분해서 분수를 보여주면 된다.

>> 5단계는 홀수,

>>> 그러니 시작은 5/1 거기서 차이(3)만큼 위는 빼고, 아래는 더한다.

>>> 나오는 것은 2/4

 

: 개선점 : 수학에 대한 이해

using System;

namespace Math00
{
    class Program
    {
        static void Main(string[] args)
        {
            // :: Read
            string input = Console.ReadLine();

            // :: Set
            int checkNumber = int.Parse(input);

            // :: Find
            int count = 1;
            int range = 1;
            int firstNumber = 1;
            while(true)
            {
                // ::: EXIT
                if (checkNumber <= range)
                    break;

                count += 1;
                firstNumber = range + 1;
                range += count;
            }

            // :: Get
            int up = 1;
            int down = 1;
            if(count % 2 == 1)
            {
                up = count - (checkNumber - firstNumber);
                down = 1 + (checkNumber - firstNumber);
            } else if(count % 2 == 0)
            {
                up = 1 + (checkNumber - firstNumber);
                down = count - (checkNumber - firstNumber);
            }

            // :: Print
            string print = string.Format("{0}/{1}", up, down);
            Console.WriteLine(print);
        }
    }
}

 

 

'C#' 카테고리의 다른 글

Javascript의 getInt16()를 C#으로 Convert  (0) 2022.12.20
GetHashCode  (0) 2021.04.23
백준 2292 : 벌집  (0) 2021.02.02
백준 1712 : 손익분기점  (0) 2021.02.01
백준 1316 : 그룹 단어 체커  (0) 2021.01.30
블로그 이미지

RIsN

,

백준 2292 : 벌집

C# 2021. 2. 2. 23:55

위의 그림과 같이 육각형으로 이루어진 벌집이 있다. 그림에서 보는 바와 같이 중앙의 방 1부터 시작해서 이웃하는 방에 돌아가면서 1씩 증가하는 번호를 주소로 매길 수 있다. 숫자 N이 주어졌을 때, 벌집의 중앙 1에서 N번 방까지 최소 개수의 방을 지나서 갈 때 몇 개의 방을 지나가는지(시작과 끝을 포함하여)를 계산하는 프로그램을 작성하시오. 예를 들면, 13까지는 3개, 58까지는 5개를 지난다.

첫째 줄에 N(1 ≤ N ≤ 1,000,000,000)이 주어진다.
입력으로 주어진 방까지 최소 개수의 방을 지나서 갈 때 몇 개의 방을 지나는지 출력한다.

:: 성공

 

: 설명 :

> 속도가 중요함 = 공식을 써서 풀라는 것...

> 처음에 시도한 것(실패) : 6이란 관련 있어보여서 받은 숫자의 6을 나눈 것을 토대로 뭔가 해볼 수 없나 공식 짜봄

>> 그랬더니 2 / 6 = 0, 7 / 6 = 1 이라는 동일 방 개수임에도 다른 문제가 생김

> 나중에 바꾼 것(성공) : 아예 범위 숫자를 파악해서 확인
>> 1,(+6) 2-7, (+12) 8-19 등 

 

: 개선점 : 수학에 대한 이해

using System;

namespace Math00
{
    class Program
    {
        static void Main(string[] args)
        {
            // :: Read
            string input = Console.ReadLine();

            // :: Set
            int checkNumber = int.Parse(input);

            // :: Find
            int count = 1;
            int range = 1;
            while(true)
            {
                // ::: EXIT
                if (checkNumber <= range)
                    break;

                int sixMultiple = 6 * count;
                count += 1;

                range += sixMultiple;
            }

            // :: Print
            string print = count.ToString();
            Console.WriteLine(print);
        }
    }
}

 

 

'C#' 카테고리의 다른 글

GetHashCode  (0) 2021.04.23
백준 1193 : 분수찾기  (0) 2021.02.03
백준 1712 : 손익분기점  (0) 2021.02.01
백준 1316 : 그룹 단어 체커  (0) 2021.01.30
백준 2941 : 크로아티아 알파벳  (0) 2021.01.29
블로그 이미지

RIsN

,

백준 1712 : 손익분기점

C# 2021. 2. 1. 23:59

월드전자는 노트북을 제조하고 판매하는 회사이다. 노트북 판매 대수에 상관없이 매년 임대료, 재산세, 보험료, 급여 등 A만원의 고정 비용이 들며, 한 대의 노트북을 생산하는 데에는 재료비와 인건비 등 총 B만원의 가변 비용이 든다고 한다.

예를 들어 A=1,000, B=70이라고 하자. 이 경우 노트북을 한 대 생산하는 데는 총 1,070만원이 들며, 열 대 생산하는 데는 총 1,700만원이 든다.

노트북 가격이 C만원으로 책정되었다고 한다. 일반적으로 생산 대수를 늘려 가다 보면 어느 순간 총 수입(판매비용)이 총 비용(=고정비용+가변비용)보다 많아지게 된다. 최초로 총 수입이 총 비용보다 많아져 이익이 발생하는 지점을 손익분기점(BREAK-EVEN POINT)이라고 한다.

A, B, C가 주어졌을 때, 손익분기점을 구하는 프로그램을 작성하시오.

첫째 줄에 A, B, C가 빈 칸을 사이에 두고 순서대로 주어진다. 
A, B, C는 21억 이하의 자연수이다.
첫 번째 줄에 손익분기점 즉 최초로 이익이 발생하는 판매량을 출력한다. 
손익분기점이 존재하지 않으면 -1을 출력한다.

:: 성공

 

: 설명 :

> 속도가 중요함 = 공식을 써서 풀라는 것...

> 공식 : 고정 비용 + (가변 비용 * 동일한 값이 되는 횟수) = 가격 * 동일한 값이 되는 횟수

>> 손익분기점 = 동일한 값이 되는 횟수 + 1
>> 뭔가 미묘함

 

: 개선점 : 수학에 대한 이해

using System;

namespace Math00
{
    class Program
    {
        static void Main(string[] args)
        {
            // :: Read
            string[] inputs = Console.ReadLine().Split(' ');

            // :: Divide
            int fixedCost = int.Parse(inputs[0]);
            int variableCost = int.Parse(inputs[1]);
            int price = int.Parse(inputs[2]);

            // :: EXIT
            if (variableCost >= price)
            {
                Console.WriteLine("-1"); 
                return;
            }

            // :: Get
            int break_evenPoint = (fixedCost / (price - variableCost)) + 1;

            // :: Print
            string print = break_evenPoint.ToString();
            Console.WriteLine(print);
        }
    }
}

 

 

'C#' 카테고리의 다른 글

백준 1193 : 분수찾기  (0) 2021.02.03
백준 2292 : 벌집  (0) 2021.02.02
백준 1316 : 그룹 단어 체커  (0) 2021.01.30
백준 2941 : 크로아티아 알파벳  (0) 2021.01.29
백준 5622 : 다이얼  (0) 2021.01.28
블로그 이미지

RIsN

,

그룹 단어란 단어에 존재하는 모든 문자에 대해서, 각 문자가 연속해서 나타나는 경우만을 말한다. 예를 들면, ccazzzzbb는 c, a, z, b가 모두 연속해서 나타나고, kin도 k, i, n이 연속해서 나타나기 때문에 그룹 단어이지만, aabbbccb는 b가 떨어져서 나타나기 때문에 그룹 단어가 아니다.

단어 N개를 입력으로 받아 그룹 단어의 개수를 출력하는 프로그램을 작성하시오.

첫째 줄에 단어의 개수 N이 들어온다. N은 100보다 작거나 같은 자연수이다. 
둘째 줄부터 N개의 줄에 단어가 들어온다. 
단어는 알파벳 소문자로만 되어있고 중복되지 않으며, 길이는 최대 100이다.
첫째 줄에 그룹 단어의 개수를 출력한다.

:: 성공

 

: 설명 :

> 문자열 단어 확인해서 True 면 1을 더한 걸 출력

 

> 문자열 단어 확인 :

>> 우선 문자열 단어를 각 문자마다 반복(for)해서 확인을 시작

>> 리스트를 사용해서 각 문자를 넣기 시작

>> 전의 문자를 저장해서 지금 문자가 전의 문자와 같으면 무시(continue)

>> False 식 : 전의 문자와 다르면서 혹시 리스트에 문자가 있으면 false

>> True 식 : 다 돌렸는데 False 식이 없으면 true

 

: 개선점 : 정규표현식에 대한 이해

using System;
using System.Collections.Generic;

namespace String00
{
    class Program
    {
        static void Main(string[] args)
        {
            // : Count
            int count = int.Parse(Console.ReadLine());

            // : Read
            int numberCount = 0;
            for (int i = 0; i < count; i++)
            {
                string input = Console.ReadLine();

                // : Get
                numberCount += Check(input) ? 1 : 0;
            }

            // : Print
            string print = numberCount.ToString();
            Console.WriteLine(print);
        }

        // : Checker
        public static bool Check(string word)
        {
            List<char> listChar = new List<char>();
            char frontChar = new char();
            for(int i = 0; i < word.Length; i++)
            {
                // :: Continue
                if (listChar.Count <= 0)
                {
                    listChar.Add(word[i]);
                    frontChar = word[i];
                    continue;
                }
                if (frontChar == word[i])
                    continue;

                // :: False
                if (listChar.Contains(word[i]) == true)
                    return false;

                listChar.Add(word[i]);
                frontChar = word[i];
            }

            // :: True
            return true;
        }
    }
}

 

 

'C#' 카테고리의 다른 글

백준 2292 : 벌집  (0) 2021.02.02
백준 1712 : 손익분기점  (0) 2021.02.01
백준 2941 : 크로아티아 알파벳  (0) 2021.01.29
백준 5622 : 다이얼  (0) 2021.01.28
백준 2908 : 상수  (0) 2021.01.27
블로그 이미지

RIsN

,