Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> การเขียนโปรแกรม

ปริศนาวางไข่


นี่คือปัญหาปริศนาที่มีชื่อเสียง สมมติว่ามีอาคารที่มี n ชั้น หากเรามีไข่ m ฟอง เราจะหาจำนวนหยดขั้นต่ำที่จำเป็นในการหาชั้นที่จะทิ้งไข่ได้อย่างปลอดภัยโดยไม่ทำให้ไข่แตกได้อย่างไร

มีประเด็นสำคัญที่ต้องจำ -

  • เมื่อไข่ไม่แตกจากชั้นที่กำหนด มันจะไม่แตกสำหรับชั้นล่างด้วย
  • หากไข่แตกจากชั้นที่กำหนด ไข่จะแตกสำหรับชั้นบนทั้งหมด
  • เวลาไข่แตกต้องทิ้ง ไม่เช่นนั้น เราสามารถนำมาใช้ใหม่ได้

อินพุตและเอาต์พุต

Input:
The number of eggs and the maximum floor. Say the number of eggs are 4 and the maximum floor is 10.
Output:
Enter number of eggs: 4
Enter max Floor: 10
Minimum number of trials: 4

อัลกอริทึม

eggTrialCount(eggs, floors)

ป้อนข้อมูล: จำนวนไข่ ชั้นสูงสุด

ผลลัพธ์ − รับจำนวนการทดลองใช้ขั้นต่ำ

Begin
   define matrix of size [eggs+1, floors+1]
   for i:= 1 to eggs, do
      minTrial[i, 1] := 1
      minTrial[i, 0] := 0
   done

   for j := 1 to floors, do
      minTrial[1, j] := j
   done

   for i := 2 to eggs, do
      for j := 2 to floors, do
         minTrial[i, j] := ∞
         for k := 1 to j, do
            res := 1 + max of minTrial[i-1, k-1] and minTrial[i, j-k]
            if res < minTrial[i, j], then
               minTrial[i,j] := res
         done
      done
   done

   return minTrial[eggs, floors]
End

ตัวอย่าง

#include<iostream>
using namespace std;

int max(int a, int b) {
   return (a > b)? a: b;
}

int eggTrialCount(int eggs, int floors) {    //minimum trials for worst case
   int minTrial[eggs+1][floors+1];    //to store minimum trials for ith egg and jth floor
   int res;

   for (int i = 1; i <= eggs; i++) {    //one trial to check from first floor, and no trial for 0th floor
      minTrial[i][1] = 1;
      minTrial[i][0] = 0;
   }

   for (int j = 1; j <= floors; j++)    //when egg is 1, we need 1 trials for each floor
      minTrial[1][j] = j;

   for (int i = 2; i <= eggs; i++) {    //for 2 or more than 2 eggs
      for (int j = 2; j <= floors; j++) {    //for second or more than second floor
         minTrial[i][j] = INT_MAX;
         for (int k = 1; k <= j; k++) {
            res = 1 + max(minTrial[i-1][k-1], minTrial[i][j-k]);
            if (res < minTrial[i][j])
               minTrial[i][j] = res;
         }
      }
   }

   return minTrial[eggs][floors];    //number of trials for asked egg and floor
}

int main () {
   int egg, maxFloor;
   cout << "Enter number of eggs: "; cin >> egg;
   cout << "Enter max Floor: "; cin >> maxFloor;
   cout << "Minimum number of trials: " << eggTrialCount(egg, maxFloor);
}

ผลลัพธ์

Enter number of eggs: 4
Enter max Floor: 10
Minimum number of trials: 4