Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- java
- 백준 11659
- 코딩테스트
- 성능테스트툴
- 버블정렬
- Spring Web MVC
- 스택
- 투포인터알고리즘
- 구간합구하기
- 재귀함수
- 프로그래머스
- 재귀와반복문
- MySQL
- Array.asList
- vm인스턴스생성
- 자바
- String.valueOf()
- 코드스테이츠 백엔드
- OOP
- Spring MVC 구성요소
- 11659
- List.of
- 인텔리제이
- 싱글톤패턴
- 코드스테이츠
- 알고리즘
- 백준
- 클라우드에서 도커 실행하기
- Spring MVC 동작원리
- GCP
Archives
- Today
- Total
순간을 기록으로
[Java] 문자열 안 중복문자 제거하기 | 인프런 | 본문
문제
풀이 1 - 사용한 문자를 기록하기
앞에서 사용했던 문자들을 기록할 배열을 만들고 새로운 문자들을 붙일 때 앞에서 나온 적이 있는지 검사하는 알고리즘입니다.
import java.util.ArrayList;
import java.util.Scanner;
/*
* 소문자 한 개 문자열이 입력되면 중복된 문자가 제거되고, 순서를 유지하는 문자열을 출력하세요.
* - 문자열을 각 문자씩 앞에서부터 접근합니다.
* - 문자에 접근하고 앞에서 나온적이 있는지 검사합니다.
* - 나온적이 없으면 문자를 붙이고, 나온적이 있으면 통과합니다.
* */
public class Main {
public static String solution(String str) {
ArrayList<Character> usedLetters = new ArrayList<>();
StringBuilder sb = new StringBuilder();
for (char ch : str.toCharArray()) {
if (!usedLetters.contains(ch)) { // 사용한 적이 없으면
sb.append(ch);
usedLetters.add(ch);
}
}
return sb.toString();
}
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
String str = in.next();
System.out.println(solution(str));
}
}
풀이 2 - String 클래스 IndexOf(문자) 활용하기
String 클래스 안에 있는 IndexOf 메서드는 문자를 입력으로 받습니다. 만약 문자열 안에 해당 문자가 여러 개 존재하면 가장 앞에 있는 문자의 인덱스를 반환합니다. 만약 문자열에 해당 문자가 없으면 -1을 리턴합니다.
// indexOf의 특성을 이용한다. indexOf(문자)는 문자열에서 해당 문자인 첫번째 인덱스를 반환한다.
import java.util.Scanner;
public class Main {
public String solution(String str) {
String answer = "";
StringBuilder sb = new StringBuilder();
for(int i=0; i<str.length(); i++) {
if(str.indexOf(str.charAt(i)) == i)
sb.append(str.charAt(i));
}
answer = sb.toString();
return answer;
}
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
String str = in.next();
Main T = new Main();
System.out.println(T.solution(str));
}
}
'Problem Solving' 카테고리의 다른 글
[Java] 두 배열 합치기 | 인프런 | 투포인터 알고리즘 (0) | 2022.04.20 |
---|---|
[Java] 뒤집은 소수 | 인프런 (0) | 2022.04.20 |
[Java] 소수 개수 구하기 | 인프런 | 에라토스테네스 체 (0) | 2022.04.20 |
[Java] 피보나치 수열 | 인프런 (0) | 2022.04.19 |
[Java] 가위바위보 | 인프런 | 배열 (0) | 2022.04.19 |
Comments