ผลต่างระหว่างรุ่นของ "Psl/ลิงก์ลิสต์"
ไปยังการนำทาง
ไปยังการค้นหา
Jittat (คุย | มีส่วนร่วม) (→โหนด) |
Jittat (คุย | มีส่วนร่วม) (→โหนด) |
||
| แถว 3: | แถว 3: | ||
== โหนด == | == โหนด == | ||
| + | === พื้นฐาน === | ||
โครงสร้างพื้นฐานของลิงก์ลิสต์คือโหนด ซึ่งโดยมากจะมีข้อมูลสองชุดคือข้อมูลในโหนดนั้นเอง กับพอยน์เตอร์ไปยังโหนดถัดไป | โครงสร้างพื้นฐานของลิงก์ลิสต์คือโหนด ซึ่งโดยมากจะมีข้อมูลสองชุดคือข้อมูลในโหนดนั้นเอง กับพอยน์เตอร์ไปยังโหนดถัดไป | ||
| แถว 31: | แถว 32: | ||
สังเกตว่าเราสามารถเขียน <tt>var->field</tt> แทน <tt>(*var).field</tt> ได้ | สังเกตว่าเราสามารถเขียน <tt>var->field</tt> แทน <tt>(*var).field</tt> ได้ | ||
| + | |||
| + | ด้านล่างเป็นตัวอย่างฟังก์ชันที่วิ่งไปในลิสต์เพื่อพิมพ์รายการในลิสต์ | ||
| + | |||
| + | <syntaxhighlight lang="cpp"> | ||
| + | void print_list(ListNode* list) | ||
| + | { | ||
| + | while(list != 0) { | ||
| + | printf("%d\n", list->value); | ||
| + | list = list->next; | ||
| + | } | ||
| + | } | ||
| + | </syntaxhighlight> | ||
| + | |||
| + | === โหนดฉบับปรับปรุง 1 และลิงก์ลิสต์แบบมีหัว (header) === | ||
== กิจกรรม == | == กิจกรรม == | ||
รุ่นแก้ไขเมื่อ 23:36, 25 มกราคม 2558
- หน้านี้เป็นส่วนหนึ่งของ problem solving lab
โหนด
พื้นฐาน
โครงสร้างพื้นฐานของลิงก์ลิสต์คือโหนด ซึ่งโดยมากจะมีข้อมูลสองชุดคือข้อมูลในโหนดนั้นเอง กับพอยน์เตอร์ไปยังโหนดถัดไป
struct ListNode {
int value;
ListNode* next;
};
ตัวอย่างการสร้างแบบตรงไปตรงมา
main()
{
ListNode* n1;
ListNode* n2;
n1 = new ListNode;
n2 = new ListNode;
n1->value = 10;
n1->next = n2;
n2->value = 40;
n2->next = 0;
print_list(n1);
}
สังเกตว่าเราสามารถเขียน var->field แทน (*var).field ได้
ด้านล่างเป็นตัวอย่างฟังก์ชันที่วิ่งไปในลิสต์เพื่อพิมพ์รายการในลิสต์
void print_list(ListNode* list)
{
while(list != 0) {
printf("%d\n", list->value);
list = list->next;
}
}