배열 [ ]
동일(유사)한 타입의 데이터를 하나의 묶음 형태로 관리하기 위해 사용되는 자료구조
같은 타입의 변수가 100개정도 필요하다면 변수명을 만드는 데에도 많은 시간과 어려움이 따르는데 이를 극복하고자 사용됨
index(위치) = length(길이) - 1
객체는 기본적으로 속성과 메소드를 가지고 있지만 배열은 유일하게 속성만을 가짐
length(길이)는 배열에서의 속성을 나타냄 (length는 배열을 생성할 때만 선언)
객체의 속성과 메소드를 사용해서 배열을 관리
객체의 속성과 메소드 등을 호출할때는 .(점)을 이용
값을 지정하지 않았을 경우의 default값(초기값) :
int |
0 |
double |
0.0 |
char |
\0 |
boolean |
false(거짓) |
객체 |
null |
ex)
자료형[] array = new 자료형[길이];
int[] arr01 = new int[5]; //int타입의 길이가 5인 배열 선언 [0, 0, 0, 0, 0]
double[] dArr01 = new double[10]; //double타입의 길이가 10인 배열 선언 [0.0, 0.0, 0.0, ......]
char[] cArr01 = new char[15]; //char타입의 길이가 15인 배열을 선언 [ , , , , , , , ......]
boolean[] bArr01 = new boolean[15]; //boolean타입의 길이가 15인 배열을 선언 [false, false .....]
int[] arr02 = new int[] {1, 2, 3, 4, 5}; //선언과 동시에 값 넣어주기
int[] arr03 = {100, 200, 300, 400, 500};
String addr = "서울시 강남구 삼성동";
arr01[0] = 10; //arr01배열의 0번째 위치에 10을 대입
arr01[1] = 11;
arr01[2] = 12;
arr01[3] = 13;
arr01[4] = 14;
System.out.println(arr01[0]); //arr01의 0번째 위치에 있는 값 출력
System.out.println(arr01); //arr01의 주소값 출력
System.out.println(Arrays.toString(arr01)); //① arr01의 전체 값 출력
System.out.println(arr01.length); //② arr01의 길이 출력
System.out.println(addr.length()); //③ 스페이스바(공백) 포함
System.out.println(addr.charAt(1)); //addr의 1번 index값
- ① Arrays.toString( ) : ( )안의 배열의 값 전체 출력 (import 필수)
- ②③ length를 출력할 때 배열에서는 괄호가 없지만 문자열에서는 괄호가 있다.
[실행결과]
10
[I@7637f22
[10, 11, 12, 13, 14]
5
11
울
예제 1.
<특정 값 대입하기>
- 100 ~ 104까지의 정수 대입
- 100 ~ 108까지의 짝수인 정수 대입
- 104 ~ 100까지의 정수 대입
int[] arr01 = new int[5];
for (int i = 0; i < arr01.length; i++) {
arr01[i] = 100 + i;
}
System.out.println(Arrays.toString(arr01));
for (int i = 0; i < arr01.length; i++) {
arr01[i] = 100 + (2 * i);
}
System.out.println(Arrays.toString(arr01));
for (int i = 0; i < arr01.length; i++) {
arr01[i] = 104 - i;
}
System.out.println(Arrays.toString(arr01));
[실행결과]
[100, 101, 102, 103, 104]
[100, 102, 104, 106, 108]
[104, 103, 102, 101, 100]
예제 2.
<length(길이)를 모르는 배열의 맨 마지막 위치(index)에 값 대입하기>
※ index = length - 1
int[] arr01 = new int[5];
arr01[arr01.length - 1] = 1000;
System.out.println(Arrays.toString(arr01));
[실행결과]
[0, 0, 0, 0, 1000]
예제 3.
<arr01의 짝수칸에 arr02의 값 순서대로 대입하기>
int[] arr01 = new int[10]; // [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
int[] arr02 = {100, 200, 300, 400, 500}; // [100, 200, 300, 400, 500]
for (int i = 0; i < arr02.length; i++) {
arr01[(i * 2) + 1] = arr02[i];
}
System.out.println(Arrays.toString(arr01));
[실행결과]
[0, 100, 0, 200, 0, 300, 0, 400, 0, 500]
예제 4.
<문자형 배열 >
※ 아스키코드 65 ~ 90 = A ~ Z
char[] cArr01 = new char[26];
char alpha = 'A';
for (int i = 0; i < cArr01.length; i++) {
cArr01[i] = alpha++;
}
System.out.println(Arrays.toString(cArr01));
System.out.println((char) (cArr01[2] + 3)); //(문자형) C(아스키코드67) + 3 = F(70)
System.out.println((cArr01[2] + 3));
char[]cat = {'C', 'A', 'T'};
for (int i = 0; i < cat.length; i++) {
cat[i] = (char) (cat[i] + 3); //캐스팅(char)
}
System.out.println(Arrays.toString(cat)); //C, A, T에 각 3씩 더한 값
[실행결과]
[A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P, Q, R, S, T, U, V, W, X, Y, Z]
F
70
[F, D, W]
예제 5.
<배열 복사>
int[] arr01 = new int[] {11, 12, 13, 14, 15};
int[] arr02 = new int[] {21, 22, 23, 24, 25};
for (int i = 0; i < arr01.length; i++) {
arr01[i] = arr02[i];
}
System.out.println(Arrays.toString(arr01));
[실행결과]
[21, 22, 23, 24, 25]
예제 6.
<String Array>
String apple = "apple";
char[] appleArray = new char[apple.length()];
for (int i = 0; i < appleArray.length; i++) {
appleArray[i] = apple.charAt(i);
}
System.out.println(Arrays.toString(appleArray));
System.out.println(appleArray);
[실행결과]
[a, p, p, l, e]
apple
예제 7.
<Lotto>
- 1 ~ 45중 랜덤한 6개의 숫자 출력
- 중복으로 나올 경우 다시 돌리기
int[] lotto = new int[6];
for (int i = 0; i < lotto.length; i++) { //6번 반복
lotto[i] = (int) (Math.random() * 45 + 1); //1 ~ 45중의 랜덤한 숫자
for (int j = 0; j < i; j++) { //중복검사
if(lotto[i] == lotto[j]) { //바로 전의 숫자와 같다면(중복된다면)
i--; //다시 돌리기
break; //탈출
}
}
}
System.out.println(Arrays.toString(lotto));
[5회 실행결과]
[11, 33, 17, 21, 36, 9]
[15, 1, 10, 4, 18, 36]
[39, 24, 19, 12, 23, 15]
[44, 17, 35, 5, 1, 38]
[22, 12, 16, 42, 40, 34]
예제 7 - 1.
<Lotto>
- 1 ~ 45중 랜덤한 6개의 숫자 출력
- 중복제거 HashSet 사용
import java.util.HashSet;
import java.util.Set;
public class Lotto {
public static void main(String[] args) {
Set<Integer> lotto = new HashSet<Integer>(); //①
while (lotto.size() < 6) { //② lotto의 크기가 6보다 작다면
lotto.add((int) (Math.random() * 45 + 1)); //③
}
System.out.println(lotto);
}
}
- ① import 필수
- ② size( ) 는 배열의 크기를 뜻한다.
- ③ add는 set에 값을 집어넣을 때 사용한다.
[5회 실행결과]
[17, 21, 40, 41, 11, 45]
[32, 18, 37, 11, 29, 30]
[1, 3, 4, 27, 12, 13]
[1, 23, 43, 28, 12, 13]
[19, 36, 23, 40, 29, 14]
예제 8.
<FizzBuzz>
- 1 ~ 20까지의 정수 중 3의배수는fizz 5의배수는buzz 15의배수는fizzbuzz를 출력
String[] fb = new String[20]; //문자열이 있기 떄문에 String로 선언
for (int i = 1; i <= fb.length ; i++) { //20번 반복
if (i % 3 == 0 && i % 5 == 0) {
fb[i - 1] = "fizzbuzz"; //0번index의 값이 1부터 시작하기 때문에 fb[i-1]
} else if(i % 5 == 0) {
fb[i - 1] = "buzz";
} else if(i % 3 == 0) {
fb[i - 1] = "fizz";
}else {
fb[i - 1] = String.valueOf(i);
}
}
System.out.println(Arrays.toString(fb));
[실행결과]
[1, 2, fizz, 4, buzz, fizz, 7, 8, fizz, buzz, 11, fizz, 13, 14, fizzbuzz, 16, 17, fizz, 19, buzz]