250x250
Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 막내의막무가내 목표 및 회고
- 2022년 6월 일상
- 막내의막무가내 플러터 flutter
- 주택가 잠실새내
- 막내의막무가내 코볼 COBOL
- 막내의막무가내
- 막내의막무가내 코틀린 안드로이드
- 막내의막무가내 안드로이드 에러 해결
- 안드로이드 Sunflower 스터디
- 막내의 막무가내
- 막내의 막무가내 알고리즘
- 막내의막무가내 안드로이드 코틀린
- 막내의막무가내 일상
- 막내의막무가내 플러터
- 안드로이드 sunflower
- 부스트코스에이스
- 주엽역 생활맥주
- 부스트코스
- 안드로이드
- 막무가내
- flutter network call
- 막내의막무가내 코틀린
- 막내의막무가내 안드로이드
- 막내의막무가내 알고리즘
- 프로그래머스 알고리즘
- 프래그먼트
- 막내의막무가내 rxjava
- Fragment
- 막내의막무가내 프로그래밍
- 막내의막무가내 SQL
Archives
- Today
- Total
막내의 막무가내 프로그래밍 & 일상
[알고리즘] SWexpert 6900 주혁이의복권당첨 본문
728x90
sw expert라는 사이트에서 처음으로 풀어본 알고리즘 문제이다. 입출력부분을 오랜만에 하여 익숙치않은 부분이 있었는데 알고리즘 풀이에는 필수적이므로 연습을 많이해야겠다고 생각했다.
/////////////////////////////////////////////////////////////////////////////////////////////
// 기본 제공코드는 임의 수정해도 관계 없습니다. 단, 입출력 포맷 주의
// 아래 표준 입출력 예제 필요시 참고하세요.
// 표준 입력 예제
// int a;
// double b;
// char g;
// String var;
// long AB;
// a = sc.nextInt(); // int 변수 1개 입력받는 예제
// b = sc.nextDouble(); // double 변수 1개 입력받는 예제
// g = sc.nextByte(); // char 변수 1개 입력받는 예제
// var = sc.next(); // 문자열 1개 입력받는 예제
// AB = sc.nextLong(); // long 변수 1개 입력받는 예제
/////////////////////////////////////////////////////////////////////////////////////////////
// 표준 출력 예제
// int a = 0;
// double b = 1.0;
// char g = 'b';
// String var = "ABCDEFG";
// long AB = 12345678901234567L;
//System.out.println(a); // int 변수 1개 출력하는 예제
//System.out.println(b); // double 변수 1개 출력하는 예제
//System.out.println(g); // char 변수 1개 출력하는 예제
//System.out.println(var); // 문자열 1개 출력하는 예제
//System.out.println(AB); // long 변수 1개 출력하는 예제
/////////////////////////////////////////////////////////////////////////////////////////////
import java.util.Scanner;
import java.util.StringTokenizer;
/*
사용하는 클래스명이 Solution 이어야 하므로, 가급적 Solution.java 를 사용할 것을 권장합니다.
이러한 상황에서도 동일하게 java Solution 명령으로 프로그램을 수행해볼 수 있습니다.
*/
class Solution
{
public static void main(String args[]) throws Exception
{
int i, k, z, index;
int testNum; // test size
int N = 0; // lottery count
int M = 0; // lottery count that I bought
String bokgwon[]; // lottery number
int bokgwonMoney[]; // lottery Winning amount
String myBokgwon[]; // Lottery Number I Have
int moneyResult = 0; // money that I won
StringTokenizer str;
Boolean isSame; //is my lottery Won
Scanner sc = new Scanner(System.in);
String line = "";
testNum = sc.nextInt();
//Repeat as many as my lottery
for (i = 0; i < testNum; i++) {
N = sc.nextInt();
M = sc.nextInt();
//initialize
bokgwon = new String[N];
bokgwonMoney = new int[N];
myBokgwon = new String[M];
//init lottery
for (k = 0; k < N; k++) {
bokgwon[k] = sc.next();
bokgwonMoney[k] = sc.nextInt();
}
//init my lottery
for (k = 0; k < M; k++) {
myBokgwon[k] = sc.next();
}
//solve Repeat as N lotteries
for (k = 0; k < N; k++) {
//Repeat as M lotteries that I bought
for (index = 0; index < M; index++) {
//isSame is flag for winning
isSame = true;
//Compare lottery number one by one
for (z = 0; z < myBokgwon[0].length(); z++) {
// * is always correct, and the rest must match the same number
if (bokgwon[k].charAt(z) == '*' || (bokgwon[k].charAt(z) == myBokgwon[index].charAt(z))) {
}
// not correct => break;
else {
isSame = false;
break;
}
}
//Check winnings with isSame(flag)
if (isSame == true) {
//add lottery money
moneyResult += bokgwonMoney[k];
}
}
}
System.out.println("#" + (i+1) + " " + moneyResult);
moneyResult=0;
}
}
}
728x90
'알고리즘 > 일반(단순구현)' 카테고리의 다른 글
[알고리즘] 프로그래머스 뉴스 클러스터링 - 2018 KAKAO BLIND RECRUITMENT (0) | 2020.03.27 |
---|---|
[알고리즘] 프로그래머스 예상 대진표 -2017 팁스타운- (0) | 2020.03.27 |
[알고리즘] 프로그래머스 스킬트리 -서머코딩/윈터코딩(~2018) (0) | 2020.03.17 |
[알고리즘] 백준 2748 피보나치 수 2 (0) | 2019.09.02 |
[알고리즘] 프로그래머스 숫자의표현 문제풀이 (0) | 2019.06.11 |
Comments