java/배열
배열 컨트롤 기본예제2
june__Park
2021. 3. 23. 10:36
package week3;
import java.util.Scanner;
public class Day11_5 {
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
int[] arr = { 10, 20 };
boolean run = true;
while (run) {
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
System.out.println();
System.out.println("[1]추가");
System.out.println("[2]삭제(인덱스)");
System.out.println("[3]삭제(값)");
System.out.println("[4]삽입");
System.out.println("[5]종료");
System.out.println("메뉴 선택: ");
int sel = scan.nextInt();
if(sel == 1) {
System.out.print("추가할 값 입력 : ");
int value = scan.nextInt();
int temp[] = new int[arr.length+1]; // 1 추가된 배열 크기 만들기
for(int i =0; i < arr.length; i++) {
temp[i] = arr[i]; // 기존에 있던 값을 복사해서 새로운 방에 값 복사 해놓기
}
temp[arr.length] = value; // temp[마지막 인덱스] = 값 넣기
arr = temp; // 완성된 업데이트된 temp 배열의 주소를 arr 에 넣기
temp = null; // temp 값 초기화 --> arr만 arr의 주소값을 가지기 위해서
}else if(sel == 2) {
// 인덱스로 삭제
System.out.print("삭제할 인덱스 입력 : ");
int del_idx = scan.nextInt();
if( del_idx <0 || del_idx >= arr.length) {
System.out.println(" 유효하지않는 인덱스 입니다 ");
continue;
}
int temp[] = new int[arr.length-1];
int idx = 0;
for(int i =0; i<arr.length; i++) {
if (del_idx != i) {
temp[idx] = arr[i];
idx++;
// i =0 -> idx = 0
// i = 1 -> idx = 1
// i=2 -> if 문 안들어옴
// i = 3 -> idx =2
// i = 4 -> idx = 3
}
}
arr = temp;
temp = null;
}else if(sel == 3) {
System.out.print("삭제할 값 입력 : ");
int del_val = scan.nextInt();
int del_idx = -1;
for(int i = 0; i < arr.length; i++) {
if(arr[i]==del_val) {
del_idx = i;
break;
}
}
if(del_idx == -1) {
System.out.println("유효하지 않는 값 입니다 ");
continue;
}
int temp[] = new int[arr.length-1];
int idx = 0;
for(int i = 0; i < arr.length; i++) {
if(del_idx != i) {
temp[idx] = arr[i];
idx++;
}
}
arr = temp;
temp = null;
}else if(sel == 4) {
System.out.print("삽입 인덱스 입력 : ");
int idx = scan.nextInt();
if( idx <0 || idx >= arr.length) {
System.out.println(" 유효하지않는 인덱스 입니다 ");
continue;
}
System.out.print("삽입 값 입력 : ");
int val = scan.nextInt();
int temp[] = new int[arr.length+1];
for(int i = 0; i < arr.length; i++) {
temp[i] = arr[i];
}
for(int i = arr.length-1 ; i >= idx; i--) {
temp[i+1] = temp[i];
}
temp[idx] = val;
arr = temp;
temp = null;
}else {
break;
}
}
scan.close();
}
}