สมมติว่าเรามีอาร์เรย์ของอุณหภูมิที่เป็นบวกซึ่งแสดงถึงอุณหภูมิ T ภารกิจคือการคำนวณว่าจะมีอุณหภูมิที่อุ่นกว่าในครั้งต่อไปกี่วันในรายการที่กำหนด
ตัวอย่าง
อินพุต-1: T =[ 73, 74, 75, 71, 69, 72, 76, 73]
ผลลัพธ์: [1, 1, 4, 2, 1 ,1 ,0,0]
คำอธิบาย: ในรายการอุณหภูมิที่กำหนด [73, 74, 75, 71, 69, 72, 76, 73] อุณหภูมิที่สูงขึ้นถัดไปคือวันที่ 1 ในทำนองเดียวกัน วันที่ 6 เป็นอุณหภูมิที่อบอุ่นที่สุดในทั้งหมด ดังนั้น เอาต์พุตจะเป็น [ 1, 1, 4, 2, 1, 1, 0, 0].
แนวทางในการแก้ปัญหานี้
เรามีรายการอุณหภูมิและเราต้องคำนวณจำนวนวันจนถึงวันที่อากาศอบอุ่นถัดไปจากอุณหภูมิที่กำหนด
เพื่อแก้ปัญหานี้ เราสามารถใช้ Stack เริ่มแรกสแต็กว่างเปล่า และเราจะตรวจสอบว่าด้านบนของสแต็กว่างเปล่าหรือไม่ จากนั้นจึงดันอุณหภูมิ ต่อไป หากอุณหภูมิที่ด้านบนของปึกน้อยกว่าอุณหภูมิที่มีอยู่ถัดไป แสดงว่าเย็นกว่า และเราจะดึงออกจากสแต็ค
เราจะตรวจสอบอีกครั้งว่าส่วนบนสุดของปึกมีอุณหภูมิสูงขึ้นหรืออุ่นขึ้น จากนั้นคำนวณวันโดยลบวันออกจากมันและเก็บดัชนีไว้ในผลลัพธ์
- ป้อนข้อมูลอุณหภูมิ
- ฟังก์ชันจำนวนเต็ม dailyTemperature(int *T) ใช้อาร์เรย์อุณหภูมิเป็นอินพุตและส่งคืนรายการอุณหภูมิที่ร้อนที่สุดถัดไป
- วนซ้ำเหนืออาร์เรย์อุณหภูมิ
- สร้างเวกเตอร์ผลลัพธ์หรืออาร์เรย์เพื่อส่งคืนรายการอุณหภูมิทั้งหมด
- สร้างสแต็กเปล่าแล้วดันอุณหภูมิในขณะที่ตรวจสอบว่า top()>T[i] จากนั้นดันเข้าไปในสแต็กแล้วคำนวณวัน
- จัดเก็บผลลัพธ์และส่งคืน
ตัวอย่าง
#include<bits/stdc++.h> using namespace std; void dailyTemp(int * T, int n) { stack < int > s; int ans[n]; memset(ans, 0, sizeof(ans)); for (int i = 0; i < n; i++) { while (!s.empty() && T[s.top()] < T[i]) { int j = s.top(); s.pop(); ans[j] = i - j; } s.push(i); } for (int i = 0; i < n; i++) { cout << ans[i] << " " << ; } } int main() { int n = 8; int T[8] = {73, 74, 75, 71, 69, 72, 76, 73}; dailyTemp(T, n); return 0; }
ผลลัพธ์
การเรียกใช้โค้ดด้านบนจะสร้างผลลัพธ์เป็น
1 1 4 2 1 1 0 0
อุณหภูมิที่อุ่นขึ้นถัดไปในอุณหภูมิที่กำหนดคือวันที่ 4