แนวคิด
ในส่วนที่เกี่ยวกับตัวเลข N หน้าที่ของเราคือกำหนดลูกบาศก์ที่สมบูรณ์แบบที่ใหญ่ที่สุดที่สามารถเกิดขึ้นได้โดยการลบตัวเลขขั้นต่ำ (อาจเป็น 0) ออกจากตัวเลข จึงสามารถลบตัวเลขใด ๆ ออกจากตัวเลขที่กำหนดเพื่อไปให้ถึงเป้าหมายได้
A ถูกเรียกว่าเป็นลูกบาศก์ที่สมบูรณ์แบบถ้า A =B^3 สำหรับจำนวนเต็ม B.
จะเห็นแล้วว่า ถ้าเลขไม่ครบก็พิมพ์ -1.
ตัวอย่าง
ให้ N =1,025 เห็นว่าถ้าลบ 0 ออกจากตัวเลขด้านบนจะได้ 125 เป็นตัวเลขที่เหลือ ซึ่งก็คือ รากที่สามของ 5(5 * 5 * 5 =125)
ให้ N =806 จะเห็นได้ว่าถ้าลบ 0 กับ 6 ก็จะเหลือ 8 ตัว คือ รากที่สามของ 2 (2 * 2 * 2 =8)
วิธีการ
เราต้องตรวจสอบทุกลำดับของตัวเลข ตรวจสอบว่าตัวเลขเป็นลูกบาศก์หรือไม่ จากนั้นเปรียบเทียบกับจำนวนลูกบาศก์สูงสุด ในการสร้างสตริงย่อยทั้งหมด เราจะลบอักขระตัวสุดท้ายเพื่อให้สามารถสร้างการเปลี่ยนแปลงครั้งถัดไปได้
ดังนั้นเราจึงมีตัวเลข num ="876" หลังจากนั้นเราจะเพิ่มแต่ละองค์ประกอบในสตริงปัจจุบันซึ่งจะให้ −
8 87 876
หลังจากนี้การเรียกซ้ำจะกลับมาด้วย "87" จากนั้น '7' จะถูกลบออกและการวนซ้ำครั้งต่อไปจะถูกเรียกซึ่งจะให้ส่วนต่อท้าย "86" ดังนั้นสิ่งนี้จะทำให้การเรียกซ้ำสำหรับ '8' เสร็จสมบูรณ์ ส่วนต่อท้ายจะเริ่มต้นจาก '7' ซึ่งจะให้ "7" และ "76" ตามด้วย "6"
ด้วยเหตุนี้ สิ่งนี้จะให้ผลสืบเนื่องทั้งหมดของหมายเลขที่กำหนด 876
ตัวอย่าง
#include <bits/stdc++.h> using namespace std; #define ll long long ll mx1 = INT_MIN; bool is_Cube(ll x1){ int found = 0; for (int i = 2; i <= (x1 / 2); i++){ if (x1 % i == 0){ if ((i * i * i) == x1) found = 1; } } if (found == 1) return true; else return false; } void printSubSeqRec(string str, int n1, int index = -1, string curr1 = ""){ if (index == n1) return; if (curr1 != ""){ ll temp = stoi(curr1); if (is_Cube(temp)) mx1 = max(mx1, temp); } for (int i = index + 1; i < n1; i++){ curr1 += str[i]; printSubSeqRec(str, n1, i, curr1); curr1 = curr1.erase(curr1.size() - 1); } return; } int main(){ int nums1 = 1025; string str1 = to_string(nums1); printSubSeqRec(str1, str1.size()); if (mx1 != INT_MIN) cout << mx1; else cout << "NOT FOUND ANY CUBE"; return 0; }
ผลลัพธ์
125