การสอบปลายภาค: PART C1

เขียนตอบแต่ละข้อเริ่มด้วยเลขข้อในรูปแบบ <เลขข้อ> เช่น
<1>
พิมพ์คำตอบโปรแกรมข้อที่ 1
...
...
และอย่าลืมกด SUBMIT ด้วย (ส่งได้หลายครั้ง จะตรวจครั้งล่าสุด)

<1>
กำหนดให้ x0 เป็นลิสต์ของสตริง
- ให้ x1 คือลิสต์ที่ได้จากการนำสองตัวติดกันใน x0 มา "รวม" กัน 
        นิยามการ "รวม" สตริงสองตัวที่ติดกันในลิสต์คือ การนำ
        ตัวอักษรสุดท้ายของตัวซ้าย มาต่อกับ ตัวอักษรแรกของตัวขวา
  เช่น x0 = ['Aa', 'Bb', 'Cc', 'Dd'] จะได้ 
      x1 = ['a'+'B', 'b'+'C', 'c'+'D'] = ['aB', 'bC', 'cD']
- ให้ x2 คือลิสต์ที่ได้จากการนำสองตัวติดกันใน x1 มา "รวม" กัน
  ต่อจากตัวอย่างที่แล้ว ได้ x2 = ['B'+'b', 'C'+'c'] = ['Bb', 'Cc']
- ให้ x3 คือลิสต์ที่ได้จากการนำสองตัวติดกันใน x2 มา "รวม" กัน
  ต่อจากตัวอย่างที่แล้ว ได้ x3 = ['b'+'C'] = ['bC']
- แล้วก็ไม่สามารถหา x4 ได้แล้ว เพราะ x3 มีตัวเดียว

จงเขียนฟังก์ชัน f(x0) ที่
- รับ x0 เป็นลิสต์ของจำนวนเต็มมีข้อมูลอย่างน้อย 1 ตัว
- คืนลิสต์ซ้อนลิสต์ [xk, ..., x2, x1, x0] 
  โดยที่ x1, x2, ... เป็นลิสต์ที่หาได้ด้วยวิธีข้างต้น
       xk คือลิสต์ที่เหลือแค่ตัวเดียว

เช่น f(['Aa', 'Bb', 'Cc', 'Dd']) ได้
    [['bC'], ['Bb', 'Cc'], ['aB', 'bC', 'cD'], ['Aa', 'Bb', 'Cc', 'Dd']]