Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 9 additions & 0 deletions src/kyungyeon/report1/Report1_1
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
2-4번 문제

byte b = 256; (8bit, 맨 앞은 부호, -2^7 ~ 2^7-1 , -128 ~ 127)
char c = ''; (char는 빈 문자 불가능)
char answer = 'no'; (char는 문자 하나까지만 가능)
float f = 3.14 (3.14f)
double d = 1.4e3f; (1.4e3, f는 float형)

정답 : 전부
18 changes: 18 additions & 0 deletions src/kyungyeon/report1/Report1_2
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
2-7번 번 문제

System.out.println("1" + "2");
System.out.println(true+"");
System.out.println('A' + 'B');
System.out.println('1' + 2);
System.out.println('1' + '2');
System.out.println('J' +"ava");
System.out.println(true + null);

정답 :
1. 12 // "12"
2. true // "true"
3. 131 // 아스키코드 'A' = 65, 'B' = 66
4. 51 // 아스키코드 '1' = 49
5. 99 // 아스키코드 '2' = 50
6. Java // 자동 형변환의 형태 Char -> String
7. error // boolean 형은 연산 불가. + null은 그냥 print 불가.
56 changes: 56 additions & 0 deletions src/kyungyeon/report1/Report1_3.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
package kyungyeon.report1;

// 2-8 번 문제 <- 이렇게 문제 번호 작성 필수.

public class Report1_3 {
public static void main(String[] args) {

// 2-8. 아래는 변수 x, y, z의 값을 서로 바꾸는 예제이다. 결과와 같이 출력되도록 코드를 넣으세요
// 예상 결과 : x=2, y=3, z=1
int x = 1;
int y = 2;
int z = 3;

// 정답
// 아래 addClass가 뭘 원하는지 모르겠어서 2가지 형태로 답을 냈습니다.

// 첫번째.
int temp = x;
x = y;
y = z;
z = temp;
System.out.println("첫번째");
System.out.println("x=" + x);
System.out.println("y=" + y);
System.out.println("z=" + z);
System.out.println();

// 두번째.
x = 1;
y = 2;
z = 3;
AddClass addClass = new AddClass(x, y, z);
addClass.test();
}
}


// 필요하다면 클래스 추가
class AddClass {
int x;
int y;
int z;

public AddClass(int x, int y, int z) {
this.x = y;
this.y = z;
this.z = x;
}

void test() {
System.out.println("두번째");
System.out.println("x=" + x);
System.out.println("y=" + y);
System.out.println("z=" + z);
}
}
19 changes: 19 additions & 0 deletions src/kyungyeon/report2/Report2_1
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
byte b = 10;
char ch = 'A';
int i = 100;
long l = 1000L;

//3-1. 다음 중 형변환을 생략할 수 있는 것은? (모두 고르시오)

b = (byte)i;
ch = (char)b;
short s = (short)ch;
float f = (float)l;
i = (int)ch;

정답 :
불가능 // 숫자 그 자체로는 범위 내이지만, i가 int 변수(4byte) 이기에 바뀔수 있음을 고려해 오류로 뱉는다.
불가능 // 숫자 그 자체로는 범위 내이지만, char 변수는 0~127, 음의 부호는 허용을 못한다.
불가능 // (char,short 2byte 이지만 범위가 달라서 형변환 필요하다고 합니다!)
가능 // 실수형이 더 넓은 범위를 표현한다.
가능 // 어떤 범위의 ch도 담을 수 있다.
20 changes: 20 additions & 0 deletions src/kyungyeon/report2/Report2_2.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
package kyungyeon.report2;
// 3-2번 문제
public class Report2_2 {
public static void main(String[] args) {
int x = 2;
int y = 5;
char c = 'A'; // 'A'의 문자코드는 65

System.out.println(y >= 5 || x < 0 && x > 2); // true. y >= 5 에서 이미 true
System.out.println(y += 10 - x++); // 13. 대입연산자가 가장 마지막. y+10-2 (x는 증가했지만 연산에 포함x)
System.out.println(x += 2); // 5. 위에서 ++로 3되었는데 여기서 5가 됨.
System.out.println(!('A' <= c && c <= 'Z')); // false. 비교연산자 양쪽이 모두 true여서 !true의 형태가 되어, false
System.out.println('C' - c); // 2. 아스키코드 상으로 2차이다.
System.out.println('5' - '0'); // 5. 같은 이유.
System.out.println(c + 1); // 66. int형으로 형변환.
System.out.println(++c); // B. 'A'에서 1증가하여 c는 'B'가 되었다.
System.out.println(c++); // B. 실제 c는 'C'가 되었지만, 여기서는 원래 c인 'B'로 출력된다.
System.out.println(c); // C.
}
}
17 changes: 17 additions & 0 deletions src/kyungyeon/report2/Report2_3.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
package kyungyeon.report2;

class Report2_3 {
public static void main(String[] args) {

//3-3. 아래는 변수의 num 값 중에서 백의 자리 이하를 버리는 코드이다.
//만일 변수 num의 값이 '456'이라면 '400'이 되고, '111'이라면 '100'이 된다.
//알맞은 코드를 넣으시오.

int num = 456;
int result = num - num % 100;
int result2 = 100 * (num / 100);

System.out.println(result);
System.out.println(result2);
}
}
11 changes: 11 additions & 0 deletions src/kyungyeon/report2/Report2_4.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
package kyungyeon.report2;

public class Report2_4 {
public static void main(String[] args) {
int numOfApples = 123; // 사과의 개수
int sizeOfBucket = 10; // 바구니의 크기(바구니에 담을 수 있는 사과의 개수)
int numOfBucket = (int) Math.ceil((double)numOfApples / sizeOfBucket); // 모든 사과를 담는데 필요한 바구니의 수

System.out.println("필요한 바구니의 수 :" + numOfBucket);
}
}
14 changes: 14 additions & 0 deletions src/kyungyeon/report2/Report2_5.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
package kyungyeon.report2;

public class Report2_5 {
public static void main(String[] args) {
//3-5. 아래는 변수 num의 값에 따라 '양수', '음수', '0'을 출력하는 코드이다.
//삼항연산자를 이용해서 빈칸에 알맞은 코드를 넣으시오.
//Hint : 삼항 연산자를 두 번 사용할 것!

int num = 10;
String result = num > 0 ? "양수" : num == 0 ? "0" : "음수";

System.out.println(result);
}
}
16 changes: 16 additions & 0 deletions src/kyungyeon/report2/Report2_6.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
package kyungyeon.report2;

public class Report2_6 {

public static void main(String[] args) {
//3-6. 아래는 화씨(Fahrenheit)를 섭씨(Celcius)로 변환하는 코드이다.
//변환 공식이 'C = 5/9*(F-32)'라고 할 때, 빈 칸에 알맞은 코드를 넣으시오.
// 단, 변환값은 소수점 셋째자리에서 반올림하며, Math.round() 함수를 사용하지 않고 처리할 것!

int fahrenheit = 100;
float celcius = (int) (5 / 9.0 * (fahrenheit - 32.0) * 100 + 0.5) / 100.0f;

System.out.println("Fahrenheit:" + fahrenheit);
System.out.println("Celcius:" + celcius);
}
}
25 changes: 25 additions & 0 deletions src/kyungyeon/report3/Report3_1
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
//4-1. 다음의 문장들을 조건식으로 표현해보세요.

//int형 변수 x가 10보다 크고 20보다 작을 때 true인 조건식
if(x > 10 && x < 20)

//char형 변수 ch가 공백이나 탭이 아닐 때 true인 조건식
if(ch != ' ' && ch != '\t')

//char형 변수 ch가 'x' 또는 'X'일 때 true인 조건식
if(ch == 'x' || ch == 'X')

//char형 변수 ch가 숫자('0'~'9')일 때 true인 조건식
if(ch >= '0' && ch <= '9')

//char형 변수 ch가 영문자(대문자 또는 소문자)일 때 true인 조건식
if((ch >= 'a' && ch <= 'z') || (ch >= 'A' && ch <= 'Z'))

//int형 변수 year가 400으로 나눠떨어지거나 또는 4로 나눠떨어지고 100으로 나눠떨어지지 않을때 true인 조건식
if(year % 400 == 0 || (year % 4 == 0 && year % 100 != 0))

//boolean형 변수 powerOn이 false일 때 true인 조건식
if(!powerOn)

//문자열 참조변수 str이 "yes"일 때 true인 조건식
if(str.equals("yes"))
36 changes: 36 additions & 0 deletions src/kyungyeon/report3/Report3_10.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
package kyungyeon.report3;

public class Report3_10 {
public static void main(String[] args) {
//4-10. 다음은 숫자맞추기 게임을 작성한 것이다. 1과 100사이의 값을 반복적으로 입력해서
//컴퓨터가 생각한 값을 맞추면 게임이 끝난다.
//사용자가 값을 입력하면, 컴퓨터는 자신이 생각한 값과 비교해서 결과를 알려준다.
//사용자가 컴퓨터가 생각한 숫자를 맞추면 게임이 끝나고 몇 번 만에 숫자를 맞췄는지 알려준다.

// 1~100사이의 임의의 값을 얻어서 answer에 저장한다.
int answer = (int) (Math.random() * 100) + 1;
int input = 0; //사용자입력을 저장할 공간
int count = 0; //시도횟수를 세기위한 변수

// 화면으로 부터 사용자입력을 받기 위해서 Scanner클래스 사용
java.util.Scanner s = new java.util.Scanner(System.in);
do {
count++;
System.out.print("1과 100사이의 값을 입력하세요 : ");
input = s.nextInt(); //입력받은 값을 변수 input에 저장한다.

if (input > answer) {
System.out.println("좀 더 작은 수 입니다.");
continue;
}
if (input < answer) {
System.out.println("좀 더 큰 수 입니다.");
continue;
}

System.out.println("정답입니다.");
System.out.println("시도 횟수 : " + count + "번");
break;
} while (true); //무한반복문
}
}
15 changes: 15 additions & 0 deletions src/kyungyeon/report3/Report3_2.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
package kyungyeon.report3;

public class Report3_2 {
public static void main(String[] args) {
//4-2. 1부터 20까지의 정수중에서 2 또는 3의 배수가 아닌 수의 총합을 구하세요.
int sum = 0;
for (int i = 1; i < 21; i++) {
if (i % 2 != 0 && i % 3 != 0) {
sum += i;
}
}

System.out.println("sum=" + sum); // 73
}
}
16 changes: 16 additions & 0 deletions src/kyungyeon/report3/Report3_3.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
package kyungyeon.report3;

public class Report3_3 {
public static void main(String[] args) {
//4-3. 1+(1+2)+(1+2+3)+(1+2+3+4)+...+(1+2+3+...+10)의 결과를 계산하세요.
int sum = 0;
int totalSum = 0;

for (int i = 1; i < 11; i++) {
sum += i;
totalSum += sum;
}

System.out.println("totalSum="+totalSum); // 220
}
}
20 changes: 20 additions & 0 deletions src/kyungyeon/report3/Report3_4.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
package kyungyeon.report3;

public class Report3_4 {
public static void main(String[] args) {
//4-4. 1+(-2)+3+(-4)+...과 같은 식으로 계속 더해나갔을 때,
//몇까지 더해야 총합이 100 이상이 되는지 구하세요.
int sum = 0; // 총합을 저장할 변수
int s = 1; // 값의 부호를 바꿔주는데 사용할 변수
int num = 0;

while (sum < 100) {
num++;
sum += num * s;
s *= -1;
}

System.out.println("num=" + num); // 199
System.out.println("sum=" + sum); // 100
}
}
23 changes: 23 additions & 0 deletions src/kyungyeon/report3/Report3_5.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
package kyungyeon.report3;

public class Report3_5 {
public static void main(String[] args) {
//4-5. 다음의 for문을 while문으로 변경하세요.
for (int i = 0; i <= 10; i++) {
for (int j = 0; j <= i; j++)
System.out.print("*");
System.out.println();
}

int i = 0;
while (i <= 10) {
int j = 0;
while (j <= i) {
System.out.print("*");
j++;
}
System.out.println();
i++;
}
}
}
14 changes: 14 additions & 0 deletions src/kyungyeon/report3/Report3_6.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
package kyungyeon.report3;

public class Report3_6 {
public static void main(String[] args) {
//4-6. 두 개의 주사위를 던졌을 때, 눈의 합이 6이 되는 모든 경우의 수를 출력하는 프로그램을 작성하세요.
for (int i = 1; i < 7; i++) {
for (int j = 1; j < 7; j++) {
if(i+j == 6){
System.out.println("첫번째 주사위: " + i + ", 두번째 주사위: " + j);
}
}
}
}
}
16 changes: 16 additions & 0 deletions src/kyungyeon/report3/Report3_7.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
package kyungyeon.report3;

public class Report3_7 {
public static void main(String[] args) {
//4-7. 숫자로 이루어진 문자열 str이 있을 때, 각 자리의 합을 더한 결과를 출력하는 코드를 완성하세요.
//만일 문자열이 "12345"라면, ‘1+2+3+4+5’의 결과인 15를 출력이 출력되어야 합니다.
String str = "12345";
int sum = 0;

for (int i = 0; i < str.length(); i++) {
sum += str.charAt(i) - '0';
}

System.out.println("sum=" + sum);
}
}
9 changes: 9 additions & 0 deletions src/kyungyeon/report3/Report3_8.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
package kyungyeon.report3;

public class Report3_8 {
public static void main(String[] args) {
//4-8. Math.random()을 이용해서 1부터 6 사이의 임의의 정수를 변수 value에 저장하는 코드를 완성하세요.
int value = (int) (Math.random() * 6) + 1;
System.out.println("value:" + value);
}
}
18 changes: 18 additions & 0 deletions src/kyungyeon/report3/Report3_9.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
package kyungyeon.report3;

public class Report3_9 {
public static void main(String[] args) {
//4-9. int 타입의 변수 num이 있을 때, 각 자리의 합을 더한 결과를 출력하는 코드를 완성하세요.
//만일 변수 num의 값이 12345라면, ‘1+2+3+4+5’의 결과인 15를 출력하세요.
//문자열로 변환하지 말고 숫자로만 처리하세요.
int num = 12345;
int sum = 0;

while (num != 0) {
sum += num % 10;
num /= 10;
}

System.out.println("sum=" + sum);
}
}
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading