Skip to content

kookiatsuetrong/homework

Repository files navigation

Homework

Homework for Java Bootcamp

CODESTAR is a coding bootcamp in Bangkok, specialized in Java and JavaScript. Our objective is to train people to get a job in leading enterprises in Thailand and some world-class companies such as Microsoft, Amazon, Google, Apple and Facebook.

In order to achieve this goal, we designed our lessons to meet the expectations carefully. For example, our homework are unique and impossible to search for the solution from any book or web site, every homework must be done by understanding of lesson.

CODESTAR เป็น Coding Bootcamp ในกรุงเทพ เป้าหมายของเราคือการฝึกคนให้พร้อมไปทำงานในบริษัทชั้นนำของไทย รวมถึงบริษัทระดับโลกอย่าง Microsoft, Amazon, Google, Apple และ Facebook

เพื่อให้ทุกอย่างเป็นไปอย่างที่ตั้งใจไว้ บทเรียนและแบบฝึกหัดจึงถูกคิดค้นขึ้นมาอย่างดี ไม่มีทางที่จะหาคำตอบจากหนังสือหรือเว็บไซต์ที่ไหนได้ คนที่มาเรียนต้องใช้ความเข้าใจอย่างแท้จริงในการทำแบบฝึกหัด

สำหรับคนที่สนใจมาเรียน ดูคอร์สเรียนได้ที่นี่ https://codestar.work/register

การบ้านแต่ละเดือนมีทั้ง Tree Search และ Dynamic Programming ใครมีเพื่อนทำได้ส่งใบสมัครงานมาได้เลย ไม่ต้องมาเรียนให้เสียเวลา support@codestar.work

https://github.com/kookiatsuetrong/homework

October 2019

1. Binary Tree

  • ตัวอย่าง: ให้เขียน Code เพื่อรับ Binary Tree เข้ามาแล้วนับจำนวน Leaf
int countLeaf(Element e) {
  if (e == null) return 0;
  if (e.left == null && e.right == null) return 1;
  return countLeaf(e.left) + countLeaf(e.right);
}
  • ให้เขียนโค้ดเพื่อรับ Binary Tree เข้ามา แล้วหาค่าใน Leaf ที่สูงที่สุด ตัวอย่างในภาพได้ผลลัพธ์คือ 9

  • ให้เขียนโค้ดเพื่อรับ Binary Tree เข้ามา แล้วเอาค่าใน Leaf มารวมกัน ตัวอย่างในภาพได้ผลลัพธ์คือ 23

  • ให้เขียนโค้ดเพื่อรับ Binary Tree เข้ามา แล้วหาค่าที่มากที่สุดของแต่ละชั้น ตัวอย่างในภาพได้ผลลัพธ์คือ 3, 8, 5, 9, 1

  • ให้เขียนโค้ดเพื่อรับ Binary Tree เข้ามา แล้วหาผลรวมของแต่ละชั้น ตัวอย่างในภาพได้ผลลัพธ์คือ 3, 15, 14, 19, 1

class Element {
  int value;
  Element left;
  Element right;
}

2. Double Domino

Double Domino จะมี 2 หน้า แต่ละหน้ามี 2 ค่า Double Domino สามารถพลิกเพื่อเอาด้านหลังขึ้นมาด้านหน้าได้ แต่หมุนซ้ายขวาไม่ได้และสลับที่กันไม่ได้

กำหนดให้มี Double Domino อยู่จำนวนหนึ่ง ให้เขียนโค้ดหาว่าจะสามารถพลิกบางอันเพื่อให้ทั้งหมดเรียงกันได้หรือไม่

3. Subset Sum Problem

ปัญหา Subset Sum โดยทั่วไปจะมีตัวเลขอยู่หลายตัว แล้วหาว่าเป็นไปได้หรือไม่ที่จะหยิบเลขบางตัวมาเพื่อให้รวมกันได้ค่าที่ต้องการ เช่นมีตัวเลข 3, 2, 4, 7, 4, 9 เป็นไปได้หรือไม่ที่จะทำให้รวมกันเป็น 19 คำตอบคือ ทำได้ เช่น 2+4+4+9

ปัญหา Subset Sum นี้ถ้าเป็นทศนิยมต้องใช้วิธี Tree Search แต่ถ้าเป็นจำนวนเต็มสามารถใช้ Dynamic Programming แก้ปัญหาได้

ปัญหานี้คล้ายๆ กับ Subset Sum คือ มีไพ่อยู่หลายใบ แต่ละใบมีตัวเลขด้านหน้าและด้านหลัง ให้พยายามหยิบไพ่มากี่ใบก็ได้แล้วเลือกว่าจะใช้ตัวเลขด้านหน้าหรือด้านหลัง แล้วเอาตัวเลขมารวมกันจะทำให้เป็นค่าที่ต้องการได้หรือไม่ ไม่จำเป็นต้องหยิบมาใช้ทุกใบ หยิบมาแค่บางใบ แต่ถ้าหยิบใบไหนมาแล้วเลือกใช้ได้แค่ค่าเดียวของไพ่ใบนั้น

  1. ให้เขียนโค้ดเพื่อหาว่าไพ่ที่มีค่าทศนิยม สามารถรวมเป็นค่าที่ต้องการได้หรือไม่ เช่น มี 4 ใบ แต่ละใบมีค่า 2 หน้า คือ (2.1 , 3.2) (1.3 , 1.5) (2.2 , 1.4) (3.1 , 1.3) ค่าที่ต้องการคือ 6.7 ทำได้โดยหยิบไพ่ 2.1 + 1.5 + 3.1

ตัวอย่างข้อมูล มีค่าที่ต้องการ ตามด้วยจำนวนไพ่ และค่าของไพ่แต่ละใบ

6.7
4
2.1 3.2
1.3 1.5
2.2 1.4
3.1 1.3
  1. ให้เขียนโค้ดเพื่อหาว่าไพ่ที่มีค่าจำนวนเต็ม สามารถรวมเป็นค่าที่ต้องการได้หรือไม่ เช่น มีไพ่ 5 ใบ แต่ละใบมีค่า 2 หน้า คือ (3,7) (4,1) (5,8) (4,3) (6,1) ค่าที่ต้องการคือ 17 สามารถทำได้เช่น 7+4+5+1

ตัวอย่างข้อมูล มีค่าที่ต้องการ ตามด้วยจำนวนไพ่ และค่าของไพ่แต่ละใบ

17
5
3 7
4 1
5 8
4 3
6 1

September 2019

0. Container

ตัวอย่างในห้องเรียน มีสินค้า N กล่อง แต่ละกล่องมีมูลค่าและน้ำหนัก ให้เลือกสินค้าใส่ตู้ Container ที่รับน้ำหนักได้จำกัด โดยให้มีมูลค่าสินค้ามากที่สุด

14 7
200 4
500 6
300 5
800 9
700 7
600 6
100 1

นั่นคือมีตู้ Container บรรทุกได้ไม่เกิน 14 ตัน มีกล่องสินค้า 7 กล่อง กล่องแรกมีมูลค่า 200 น้ำหนัก 4 ตัน และกล่องสุดท้ายมีมูลค่า 100 น้ำหนัก 1 ตัน

  1. ใช้วิธี Greedy
  2. เมื่อน้ำหนักเป็นเลขทศนิยม ใช้วิธี Branch And Bound
  3. เมื่อน้ำหนักเป็นจำนวนเต็ม ใช้วิธี Dynamic Programming

1. Prism

Prism มี 3 หน้า แต่ละหน้ามีตัวเลขกำกับไว้ เมื่อหมุน Prism จะมีตัวเลขถัดไปมาแทน เช่น [3,2,5] เมื่อหมุนจะได้ [5,3,2] และหมุนอีกทีได้ [2,5,3] กำหนดตัวเลข T คือเป้าหมายที่ต้องการ ให้เขียนโค้ดเพื่อหาว่าเป็นไปได้หรือไม่ ที่จะหมุน Prism จำนวน N ชิ้น แล้วให้ผลรวมตัวกลางเท่ากับตัวเลข T

  1. ตัวเลขแต่ละหน้าเป็นจำนวนทศนิยม (Depth-First Search)
  2. ตัวเลขแต่ละหน้าเป็นจำนวนเต็ม (Dynamic Programming)

กำหนดให้มีข้อมูลคือ T, N และ ตามด้วยข้อมูลแต่ละหน้าของ Prism

14 4
3 2 5
2 1 7
3 1 4
1 6 5

ข้อมูลนี้มีเป้าหมายคือ 14 และมี Prism จำนวน 4 ชิ้น สามารถหมุน Prism ให้ผลรวมเป็นค่าที่ต้องการได้เช่น

5 3 2
2 1 7
1 4 3
1 6 5

ผลรวมตรงกลางคือ 3 + 1 + 4 + 6 = 14 พิมพ์คำตอบ Yes ถ้าเป็นไปได้

หรือ

11 3
1 3 5
2 4 6
7 3 1

ไม่มีทางหมุน Prism ทั้ง 3 ตัว ให้ได้ผลรวมเป็น 11 ได้ พิมพ์คำตอบ No ถ้าเป็นไปไม่ได้

2. Domino Prism

Prism มี 3 หน้า ในแต่ละหน้ามีตัวเลข 2 ตัว เมื่อหมุน Prism จะมีตัวเลขจากหน้าถัดไปขึ้นมาแทน

1 2                       2 3
3 1   ====> Rotate ====>  1 2
2 3                       3 1

ข้อมูลมีจำนวนของ Prism และ รายละเอียดของ Prism แต่ละตัว

5
3 1    3 2    1 2    3 1    1 4
2 3    1 4    4 2    2 1    3 4
1 2    3 4    2 1    1 3    3 2

จากข้อมูลข้างบน เมื่อหมุน Prism ตัวแรกและตัวสุดท้าย แถวกลางจากเชื่อมต่อกันได้

1 2    3 2    1 2    3 1    3 2
3 1    1 4    4 2    2 1    1 4  ====> Middle layer are connected
2 3    3 4    2 1    1 3    3 4
  1. ให้เขียนโค้ดเพื่อหาว่า Prism ที่กำหนดให้สามารถหมุนมา เพื่อให้ตรงกลางเชื่อมต่อกันได้เหมือน Domino หรือไม่ โดยไม่ต้องสลับที่ Prism ใช้ลำดับเดิมที่ให้มา

  2. ให้เขียนโค้ดหาว่าถ้าหยิบและหมุน Prism ที่ให้มาวางต่อกัน เพื่อให้ตรงกลางต่อกันแบบ Domino ได้หรือไม่ โดยที่ Prism ที่มาต่อกันจะมีลำดับก่อนหลังยังไงก็ได้

August 2019

Divide & Conquer in Binary Tree

จาก Binary Tree ที่จะส่งเข้าไปใน Method ซึ่งใน Binary Tree อาจจะมีข้อมูลนับล้านตัว ให้เขียนโค้ดหาคำตอบดังนี้

  • หา Leaf ที่มีค่ามากที่สุด ตัวอย่างในภาพคือ 9

  • ค่าผลรวมของค่าใน Leaf ตัวอย่างในภาพคือ 5 + 9 + 1 + 5 + 1 + 2 = 23

  • ค่าที่มากที่สุดจาก Root ไปยัง Leaf ตัวอย่างในภาพคือ 3 + 7 + 2 + 9 = 21

  • ให้พิมพ์ผลรวมของแต่ละชั้น ตัวอย่างในภาพคือ 3, 15, 14, 19, 1

ตัวอย่างการหาค่าทั้งหมดใน Tree

int getSum(Node c) {
	if (c == null) return 0;
	return c.value + getSum(c.left) + getSum(c.right);
}

ม้าหมุน

(Breadth-First Search, Depth-First Search, Iterative Deepening for NP-Complete Problem)

ม้าหมุนแต่ละตัวจะมี 4 ขา แต่ละขามีสีหรือตัวเลขกำกับไว้ ม้าหมุนสามารถหมุนได้ทีละ 90 องศา ให้เขียนโค้ดเพื่อหมุนให้ขาที่ติดกัน มีสีหรือตัวเลขเดียวกัน ให้พิมพ์จำนวนการหมุนที่น้อยที่สุดออกมาถ้าเป็นไปได้ หรือพิมพ์ Impossible ถ้าเป็นไปไม่ได้

ตัวอย่างมีม้าหมุน 6 ตัว แบ่งเป็น 2 x 3 ตัว แต่ละตัวมีข้อมูลตามเข็มนาฬิกาตามภาพข้างบน ม้าหมุนตัวแรกมีค่า 1 2 3 4

2 3
1 2 3 4
5 3 4 2
3 2 1 5
4 2 5 3
2 4 3 1
4 3 5 2

ตัวอย่างผลลัพธ์จากภาพคือหมุน 4 ครั้ง

Square Domino

(Breadth-First Search, Depth-First Search)

Square Domino แต่ละตัวมี 4 ช่อง ซึ่งสามารถหมุนได้ครั้งละ 90 องศา เพื่อเอาด้านที่เหมือนกันมาต่อกัน ดังภาพ

ตัวอย่างข้อมูลมี Square Domino 6 ตัว แต่ละตัวมีข้อมูลเรียงตามเข็มนาฬิกา ตัวแรกคือ 5 1 2 4

6
5 1 2 4
1 2 3 4
2 1 5 3
2 1 5 3
5 3 4 2
5 1 2 3

ให้เขียนโค้ดหาว่าสามารถวาง Square Domino ให้เรียงเป็นเส้นตรงเดียวกันได้หรือไม่ โดยไม่จำเป็นต้องเรียงตามลำดับ

Backup Homework

Containers

Merging two consecutive stacks of X containers and Y containers takes 2 * X * Y minutes. For example you have two stacks with 3 and 4 containers, it will take 2*(3+4) = 14 minutes. Write code to merge all stacks of containers by merging two consecutive stacks to a single stack in the minimum amount of time.

For example, you have stacks [4,2,3]

You can merge in two ways: |4-2|-3 and 4-|2-3|. The first way takes 2*(4+2) = 12 minutes to become [6,3] and 2*(6+3) = 18 minutes for the second merge. Total time is 30 minutes.

The second way is to take 2*(2+3) = 10 minutes to become [4,5] and 2*(4+5) = 18 minutes, the total time is 28 minutes which is faster than the first way.

Input

3
4 2 3

Output

28

Log

เลื่อยไฟฟ้าในโรงงานจะทำงานได้ดี ถ้าท่อนซุงที่เข้ามาเรียงลำดับจากน้อยไปมาก ให้เขียนโค้ดเพื่อหาว่า จะดึงท่อนซุงออกไปกี่อันให้น้อยที่สุด เพื่อให้เลื่อยไฟฟ้าทำงานได้ดี

double[] log = { 2.5, 1.7, 2.3, 2.4 }; 
// เอาอันแรกออกไป จะเหลือข้อมูลที่เรียงลำดับกัน
double[] log = { 1.2, 1.1, 1.5, 2.0, 1.7, 1.8 };
// ทำได้หลายแบบ เช่น เอา 1.1 กับ 2.0 ออกไปจะเหลือ 4 ท่อน

About

Homework for Java Bootcamp

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published