출처: https://school.programmers.co.kr/learn/courses/30/lessons/12919
String형 배열 seoul의 element중 "Kim"의 위치 x를 찾아, "김서방은 x에 있다"는 String을 반환하는 함수, solution을 완성하세요. seoul에 "Kim"은 오직 한 번만 나타나며 잘못된 값이 입력되는 경우는 없습니다.
제한 사항
seoul은 길이 1 이상, 1000 이하인 배열입니다.
seoul의 원소는 길이 1 이상, 20 이하인 문자열입니다.
"Kim"은 반드시 seoul 안에 포함되어 있습니다.
입출력 예
seoul return
["Jane", "Kim"] "김서방은 1에 있다"
내가 작성한 코드문
class Solution {
public String solution(String[] seoul) {
String answer = "";
int idx = 0;
//"Kim"의 위치 x를 찾아, "김서방은 x에 있다"는 String을 반환하는 함수
for(int i = 0; i < seoul.length; i++){
if(seoul[i].equals("Kim")){
idx = i;
answer = "김서방은 " + idx +"에 있다";
}
}
return answer;
}
}
맨 처음에 equals가 아닌 == 로 해서 idx 변수에 i가 저장 안되는 현상이 있었다.
그외엔 없었다.
다른 사람의 풀이
import java.util.Arrays;
public class FindKim {
public String findKim(String[] seoul){
//x에 김서방의 위치를 저장하세요.
int x = Arrays.asList(seoul).indexOf("Kim");
return "김서방은 "+ x + "에 있다";
}
// 실행을 위한 테스트코드입니다.
public static void main(String[] args) {
FindKim kim = new FindKim();
String[] names = {"Queen", "Tod","Kim"};
System.out.println(kim.findKim(names));
}
}
public class FindKim {
public String findKim(String[] seoul){
//x에 김서방의 위치를 저장하세요.
int x = 0;
for(int i=0; i<seoul.length; i++){
if(seoul[i].equals("Kim")) {
x = i ;
}
}
return "김서방은 "+ x + "에 있다";
}
// 실행을 위한 테스트코드입니다.
public static void main(String[] args) {
FindKim kim = new FindKim();
String[] names = {"Queen", "Tod","Kim"};
System.out.println(kim.findKim(names));
}
}
public class FindKim {
public String findKim(String[] seoul){
//x에 김서방의 위치를 저장하세요.
int x = 0;
while(x<seoul.length){
if(seoul[x] == "Kim")
break;
else x++;
}
return "김서방은 "+ x + "에 있다";
}
// 실행을 위한 테스트코드입니다.
public static void main(String[] args) {
FindKim kim = new FindKim();
String[] names = {"Queen", "Tod","Kim"};
System.out.println(kim.findKim(names));
}
}