#include &lt;bits/stdc++.h&gt;
using namespace std;

enum Status { AT_ORIGIN, IN_TRANSIT, OUT_FOR_DELIVERY, DELIVERED };

struct Parcel {
    string tracking;
    string sender, receiver;
    string origin, destination;
    double weightKg{};
    int postage{};
    int declaredValue{};
    Status status{};
    string acceptDate;
    string deliverDate; // อาจว่างถ้ายังไม่ส่งสำเร็จ
};

/* ---------- Utilities ---------- */
string statusName(Status s){
    switch(s){
        case AT_ORIGIN: return &quot;AT_ORIGIN&quot;;
        case IN_TRANSIT: return &quot;IN_TRANSIT&quot;;
        case OUT_FOR_DELIVERY: return &quot;OUT_FOR_DELIVERY&quot;;
        case DELIVERED: return &quot;DELIVERED&quot;;
    }
    return &quot;?&quot;;
}

void printRow(const Parcel&amp; p){
    cout &lt;&lt; left
         &lt;&lt; setw(13) &lt;&lt; p.tracking
         &lt;&lt; setw(12) &lt;&lt; p.sender.substr(0,10)
         &lt;&lt; setw(12) &lt;&lt; p.receiver.substr(0,10)
         &lt;&lt; setw(8)  &lt;&lt; p.origin
         &lt;&lt; setw(8)  &lt;&lt; p.destination
         &lt;&lt; setw(6)  &lt;&lt; fixed &lt;&lt; setprecision(1) &lt;&lt; p.weightKg
         &lt;&lt; setw(7)  &lt;&lt; p.postage
         &lt;&lt; setw(8)  &lt;&lt; p.declaredValue
         &lt;&lt; setw(19) &lt;&lt; statusName(p.status)
         &lt;&lt; setw(12) &lt;&lt; p.acceptDate
         &lt;&lt; setw(12) &lt;&lt; (p.deliverDate.empty() ? &quot;-&quot; : p.deliverDate)
         &lt;&lt; &quot;\n&quot;;
}

void printTable(const vector&lt;Parcel&gt;&amp; v){
    cout &lt;&lt; left
         &lt;&lt; setw(13) &lt;&lt; &quot;Tracking&quot;
         &lt;&lt; setw(12) &lt;&lt; &quot;Sender&quot;
         &lt;&lt; setw(12) &lt;&lt; &quot;Receiver&quot;
         &lt;&lt; setw(8)  &lt;&lt; &quot;From&quot;
         &lt;&lt; setw(8)  &lt;&lt; &quot;To&quot;
         &lt;&lt; setw(6)  &lt;&lt; &quot;Kg&quot;
         &lt;&lt; setw(7)  &lt;&lt; &quot;Fee&quot;
         &lt;&lt; setw(8)  &lt;&lt; &quot;Value&quot;
         &lt;&lt; setw(19) &lt;&lt; &quot;Status&quot;
         &lt;&lt; setw(12) &lt;&lt; &quot;AcceptDate&quot;
         &lt;&lt; setw(12) &lt;&lt; &quot;DeliverDate&quot; &lt;&lt; &quot;\n&quot;;
    cout &lt;&lt; string(117,'-') &lt;&lt; &quot;\n&quot;;
    for (auto &amp;p : v) printRow(p);
    cout &lt;&lt; &quot;\n&quot;;
}

/* ---------- Sample Data (10 รายการ) ---------- */
vector&lt;Parcel&gt; sampleData(){
    return {
        {&quot;TH010001&quot;, &quot;Somchai&quot;,  &quot;Aor&quot;,      &quot;BKK&quot;,&quot;CNX&quot;, 1.2,  60, 3000, IN_TRANSIT,        &quot;2025-10-20&quot;, &quot;&quot;},
        {&quot;TH010009&quot;, &quot;May&quot;,      &quot;Ton&quot;,      &quot;BKK&quot;,&quot;HKT&quot;, 2.0, 110, 2500, AT_ORIGIN,         &quot;2025-10-22&quot;, &quot;&quot;},
        {&quot;TH010004&quot;, &quot;Jane&quot;,     &quot;Beam&quot;,     &quot;CNX&quot;,&quot;BKK&quot;, 0.5,  45, 1200, OUT_FOR_DELIVERY,  &quot;2025-10-18&quot;, &quot;&quot;},
        {&quot;TH010002&quot;, &quot;Pond&quot;,     &quot;Mint&quot;,     &quot;BKK&quot;,&quot;KKN&quot;, 3.4, 160, 4500, IN_TRANSIT,        &quot;2025-10-19&quot;, &quot;&quot;},
        {&quot;TH010006&quot;, &quot;View&quot;,     &quot;Linn&quot;,     &quot;HKT&quot;,&quot;BKK&quot;, 0.8,  55,  800, DELIVERED,         &quot;2025-10-10&quot;, &quot;2025-10-13&quot;},
        {&quot;TH010007&quot;, &quot;Bank&quot;,     &quot;Game&quot;,     &quot;KKN&quot;,&quot;BKK&quot;, 1.0,  60, 2000, IN_TRANSIT,        &quot;2025-10-21&quot;, &quot;&quot;},
        {&quot;TH010003&quot;, &quot;Noon&quot;,     &quot;Mhee&quot;,     &quot;BKK&quot;,&quot;CTI&quot;, 5.2, 220, 7000, AT_ORIGIN,         &quot;2025-10-23&quot;, &quot;&quot;},
        {&quot;TH010010&quot;, &quot;Pop&quot;,      &quot;Fon&quot;,      &quot;CNX&quot;,&quot;CTI&quot;, 0.4,  40,  500, DELIVERED,         &quot;2025-10-08&quot;, &quot;2025-10-11&quot;},
        {&quot;TH010008&quot;, &quot;Tle&quot;,      &quot;Nune&quot;,     &quot;CTI&quot;,&quot;CNX&quot;, 1.7,  90, 1800, OUT_FOR_DELIVERY,  &quot;2025-10-22&quot;, &quot;&quot;},
        {&quot;TH010005&quot;, &quot;First&quot;,    &quot;Boat&quot;,     &quot;BKK&quot;,&quot;CNX&quot;, 2.8, 150, 3200, IN_TRANSIT,        &quot;2025-10-17&quot;, &quot;&quot;}
    };
}

/* ---------- การเรียงลำดับ: Selection Sort ตาม tracking ---------- */
void selectionSortByTracking(vector&lt;Parcel&gt;&amp; a){
    int n = (int)a.size();
    for(int i=0;i&lt;n-1;i++){
        int minIdx = i;
        for(int j=i+1;j&lt;n;j++)
            if (a[j].tracking &lt; a[minIdx].tracking) minIdx = j;
        if (minIdx != i) swap(a[i], a[minIdx]);
    }
}

/* ---------- ค้นหาแบบไบนารี (ต้องเรียงแล้ว) ---------- */
int binarySearchTracking(const vector&lt;Parcel&gt;&amp; a, const string&amp; key){
    int L = 0, R = (int)a.size()-1;
    while (L &lt;= R){
        int M = (L+R)/2;
        if (a[M].tracking == key) return M;
        if (a[M].tracking &lt; key)  L = M+1;
        else                      R = M-1;
    }
    return -1;
}

/* ---------- การแก้ไข/ลบ/เพิ่ม ---------- */
bool updateStatus(vector&lt;Parcel&gt;&amp; a, const string&amp; key, Status s, const string&amp; deliverDate=&quot;&quot;){
    int idx = binarySearchTracking(a, key);
    if (idx &lt; 0) return false;
    a[idx].status = s;
    if (s == DELIVERED &amp;&amp; !deliverDate.empty())
        a[idx].deliverDate = deliverDate;
    return true;
}

bool removeByTracking(vector&lt;Parcel&gt;&amp; a, const string&amp; key){
    int idx = binarySearchTracking(a, key);
    if (idx &lt; 0) return false;
    a.erase(a.begin()+idx);
    return true;
}

void addParcel(vector&lt;Parcel&gt;&amp; a, const Parcel&amp; p){
    // แทรกแล้วเรียงใหม่ง่ายที่สุดสำหรับงานนี้ (n เล็ก)
    a.push_back(p);
    selectionSortByTracking(a);
}

/* ---------- กรองตามสถานะ ---------- */
vector&lt;Parcel&gt; filterByStatus(const vector&lt;Parcel&gt;&amp; a, Status s){
    vector&lt;Parcel&gt; out;
    for (auto &amp;p : a) if (p.status == s) out.push_back(p);
    return out;
}

/* ---------- เดโมการใช้งานตามใบงาน ---------- */
int main(){
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    // 1) โหลดข้อมูลตัวอย่าง + แสดง
    auto db = sampleData();
    cout &lt;&lt; &quot;=== ข้อมูลเริ่มต้น (10 รายการ) ===\n&quot;;
    printTable(db);

    // 2) เรียงลำดับตาม tracking (Selection Sort) แล้วแสดง
    selectionSortByTracking(db);
    cout &lt;&lt; &quot;=== หลังเรียงลำดับด้วย Selection Sort (tracking) ===\n&quot;;
    printTable(db);

    // 3) ค้นหาเลขพัสดุ (Binary Search) &ndash; ตัวอย่าง: เจอ และ ไม่เจอ
    string k1 = &quot;TH010006&quot;, k2 = &quot;TH999999&quot;;
    int idx1 = binarySearchTracking(db, k1);
    int idx2 = binarySearchTracking(db, k2);
    cout &lt;&lt; &quot;ค้นหา &quot; &lt;&lt; k1 &lt;&lt; &quot; -&gt; &quot; &lt;&lt; (idx1&gt;=0 ? &quot;พบที่ index &quot;+to_string(idx1) : &quot;ไม่พบ&quot;) &lt;&lt; &quot;\n&quot;;
    cout &lt;&lt; &quot;ค้นหา &quot; &lt;&lt; k2 &lt;&lt; &quot; -&gt; &quot; &lt;&lt; (idx2&gt;=0 ? &quot;พบ&quot; : &quot;ไม่พบ&quot;) &lt;&lt; &quot;\n\n&quot;;

    // 4) อัปเดตสถานะ: ส่งสำเร็จ
    cout &lt;&lt; &quot;=== อัปเดตสถานะ &quot; &lt;&lt; k1 &lt;&lt; &quot; เป็น DELIVERED ===\n&quot;;
    if (updateStatus(db, k1, DELIVERED, &quot;2025-10-23&quot;)) printTable(db);

    // 5) ลบพัสดุด้วย tracking
    cout &lt;&lt; &quot;=== ลบพัสดุ TH010003 ===\n&quot;;
    removeByTracking(db, &quot;TH010003&quot;);
    printTable(db);

    // 6) กรองแสดงเฉพาะสถานะ OUT_FOR_DELIVERY
    cout &lt;&lt; &quot;=== กรองสถานะ OUT_FOR_DELIVERY ===\n&quot;;
    auto ofd = filterByStatus(db, OUT_FOR_DELIVERY);
    printTable(ofd);

    // 7) เพิ่มรายการใหม่
    cout &lt;&lt; &quot;=== เพิ่มรายการใหม่ และเรียงอัตโนมัติ ===\n&quot;;
    addParcel(db, {&quot;TH010000&quot;, &quot;Art&quot;, &quot;Om&quot;, &quot;BKK&quot;,&quot;CNX&quot;,0.7,50,500, AT_ORIGIN, &quot;2025-10-24&quot;,&quot;&quot;});
    printTable(db);

    return 0;
}
#include <bits/stdc++.h>
using namespace std;
enum Status { AT_ORIGIN, IN_TRANSIT, OUT_FOR_DELIVERY, DELIVERED };
struct Parcel {
string tracking;
string sender, receiver;
string origin, destination;
double weightKg{};
int postage{};
int declaredValue{};
Status status{};
string acceptDate;
string deliverDate; // อาจว่างถ้ายังไม่ส่งสำเร็จ
};
/* ---------- Utilities ---------- */
string statusName(Status s){
switch(s){
case AT_ORIGIN: return "AT_ORIGIN";
case IN_TRANSIT: return "IN_TRANSIT";
case OUT_FOR_DELIVERY: return "OUT_FOR_DELIVERY";
case DELIVERED: return "DELIVERED";
}
return "?";
}
void printRow(const Parcel& p){
cout << left
<< setw(13) << p.tracking
<< setw(12) << p.sender.substr(0,10)
<< setw(12) << p.receiver.substr(0,10)
<< setw(8) << p.origin
<< setw(8) << p.destination
<< setw(6) << fixed << setprecision(1) << p.weightKg
<< setw(7) << p.postage
<< setw(8) << p.declaredValue
<< setw(19) << statusName(p.status)
<< setw(12) << p.acceptDate
<< setw(12) << (p.deliverDate.empty() ? "-" : p.deliverDate)
<< "\n";
}
void printTable(const vector<Parcel>& v){
cout << left
<< setw(13) << "Tracking"
<< setw(12) << "Sender"
<< setw(12) << "Receiver"
<< setw(8) << "From"
<< setw(8) << "To"
<< setw(6) << "Kg"
<< setw(7) << "Fee"
<< setw(8) << "Value"
<< setw(19) << "Status"
<< setw(12) << "AcceptDate"
<< setw(12) << "DeliverDate" << "\n";
cout << string(117,'-') << "\n";
for (auto &p : v) printRow(p);
cout << "\n";
}
/* ---------- Sample Data (10 รายการ) ---------- */
vector<Parcel> sampleData(){
return {
{"TH010001", "Somchai", "Aor", "BKK","CNX", 1.2, 60, 3000, IN_TRANSIT, "2025-10-20", ""},
{"TH010009", "May", "Ton", "BKK","HKT", 2.0, 110, 2500, AT_ORIGIN, "2025-10-22", ""},
{"TH010004", "Jane", "Beam", "CNX","BKK", 0.5, 45, 1200, OUT_FOR_DELIVERY, "2025-10-18", ""},
{"TH010002", "Pond", "Mint", "BKK","KKN", 3.4, 160, 4500, IN_TRANSIT, "2025-10-19", ""},
{"TH010006", "View", "Linn", "HKT","BKK", 0.8, 55, 800, DELIVERED, "2025-10-10", "2025-10-13"},
{"TH010007", "Bank", "Game", "KKN","BKK", 1.0, 60, 2000, IN_TRANSIT, "2025-10-21", ""},
{"TH010003", "Noon", "Mhee", "BKK","CTI", 5.2, 220, 7000, AT_ORIGIN, "2025-10-23", ""},
{"TH010010", "Pop", "Fon", "CNX","CTI", 0.4, 40, 500, DELIVERED, "2025-10-08", "2025-10-11"},
{"TH010008", "Tle", "Nune", "CTI","CNX", 1.7, 90, 1800, OUT_FOR_DELIVERY, "2025-10-22", ""},
{"TH010005", "First", "Boat", "BKK","CNX", 2.8, 150, 3200, IN_TRANSIT, "2025-10-17", ""}
};
}
/* ---------- การเรียงลำดับ: Selection Sort ตาม tracking ---------- */
void selectionSortByTracking(vector<Parcel>& a){
int n = (int)a.size();
for(int i=0;i<n-1;i++){
int minIdx = i;
for(int j=i+1;j<n;j++)
if (a[j].tracking < a[minIdx].tracking) minIdx = j;
if (minIdx != i) swap(a[i], a[minIdx]);
}
}
/* ---------- ค้นหาแบบไบนารี (ต้องเรียงแล้ว) ---------- */
int binarySearchTracking(const vector<Parcel>& a, const string& key){
int L = 0, R = (int)a.size()-1;
while (L <= R){
int M = (L+R)/2;
if (a[M].tracking == key) return M;
if (a[M].tracking < key) L = M+1;
else R = M-1;
}
return -1;
}
/* ---------- การแก้ไข/ลบ/เพิ่ม ---------- */
bool updateStatus(vector<Parcel>& a, const string& key, Status s, const string& deliverDate=""){
int idx = binarySearchTracking(a, key);
if (idx < 0) return false;
a[idx].status = s;
if (s == DELIVERED && !deliverDate.empty())
a[idx].deliverDate = deliverDate;
return true;
}
bool removeByTracking(vector<Parcel>& a, const string& key){
int idx = binarySearchTracking(a, key);
if (idx < 0) return false;
a.erase(a.begin()+idx);
return true;
}
void addParcel(vector<Parcel>& a, const Parcel& p){
// แทรกแล้วเรียงใหม่ง่ายที่สุดสำหรับงานนี้ (n เล็ก)
a.push_back(p);
selectionSortByTracking(a);
}
/* ---------- กรองตามสถานะ ---------- */
vector<Parcel> filterByStatus(const vector<Parcel>& a, Status s){
vector<Parcel> out;
for (auto &p : a) if (p.status == s) out.push_back(p);
return out;
}
/* ---------- เดโมการใช้งานตามใบงาน ---------- */
int main(){
ios::sync_with_stdio(false);
cin.tie(nullptr);
// 1) โหลดข้อมูลตัวอย่าง + แสดง
auto db = sampleData();
cout << "=== ข้อมูลเริ่มต้น (10 รายการ) ===\n";
printTable(db);
// 2) เรียงลำดับตาม tracking (Selection Sort) แล้วแสดง
selectionSortByTracking(db);
cout << "=== หลังเรียงลำดับด้วย Selection Sort (tracking) ===\n";
printTable(db);
// 3) ค้นหาเลขพัสดุ (Binary Search) – ตัวอย่าง: เจอ และ ไม่เจอ
string k1 = "TH010006", k2 = "TH999999";
int idx1 = binarySearchTracking(db, k1);
int idx2 = binarySearchTracking(db, k2);
cout << "ค้นหา " << k1 << " -> " << (idx1>=0 ? "พบที่ index "+to_string(idx1) : "ไม่พบ") << "\n";
cout << "ค้นหา " << k2 << " -> " << (idx2>=0 ? "พบ" : "ไม่พบ") << "\n\n";
// 4) อัปเดตสถานะ: ส่งสำเร็จ
cout << "=== อัปเดตสถานะ " << k1 << " เป็น DELIVERED ===\n";
if (updateStatus(db, k1, DELIVERED, "2025-10-23")) printTable(db);
// 5) ลบพัสดุด้วย tracking
cout << "=== ลบพัสดุ TH010003 ===\n";
removeByTracking(db, "TH010003");
printTable(db);
// 6) กรองแสดงเฉพาะสถานะ OUT_FOR_DELIVERY
cout << "=== กรองสถานะ OUT_FOR_DELIVERY ===\n";
auto ofd = filterByStatus(db, OUT_FOR_DELIVERY);
printTable(ofd);
// 7) เพิ่มรายการใหม่
cout << "=== เพิ่มรายการใหม่ และเรียงอัตโนมัติ ===\n";
addParcel(db, {"TH010000", "Art", "Om", "BKK","CNX",0.7,50,500, AT_ORIGIN, "2025-10-24",""});
printTable(db);
return 0;
}