22 กรกฎาคม 2552

DTS_04 15/07/2552

เรื่อง Linked List

ลิงค์ลิสต์ (Linked List) เป็นวิธีการเก็บข้อมูลอย่างต่อเนื่องของอิลิเมนต์ต่าง ๆ โดยมีพอยเตอร์เป็นตัวเชื่อมต่อแต่ละอิลิเมนท์ เรียกว่าโนด (Node) ซึ่ง
ในแต่ละโนดจะประกอบไปด้วย 2 ส่วน คือ Data จะเก็บข้อมูลของอิลิเมนท์ และ ส่วนที่สอง คือ Link Field จะทำหน้าที่เก็บ ตำแหน่งของโนดต่อไปในลิสต์ ส่วนของ data ป็นรายการเดี่ยว หรือเป็นเรคคอร์ดก็ได้ส่วนของ link จะเป็นส่วนที่เก็บตำแหน่ง ของโหนดถัดไป ในโหนดสุดท้ายจะเก็บค่า Null ซึ่งไม่ได้ชี้ไปยังตำแหน่งใด ๆ เป็นตัวบอกการสิ้นสุดของลิสต์

โครงสร้างข้อมูลแบบลิงค์ลิสต์

โครงสร้างข้อมูลแบบลิงค์ลิสต์จะแบ่งเป็น 2 ส่วน คือ
1. Head Structure
2. Data Node Structure

กระบวนงานและฟังก์ชั่นที่ใช้ดำเนินงานพื้นฐาน

1. กระบวนงาน Create Listหน้าที่ สร้างลิสต์ว่าง ผลลัพธ์ ลิสต์ว่าง
2. กระบวนงาน Insert Node หน้าที่เพิ่มข้อมูลลงไปในลิสต์บริเวณตำแหน่งที่ต้องการข้อมูลนำเข้า ลิสต์ ข้อมูล และตำแหน่ง ผลลัพธ์ ลิสต์ที่มีการเปลี่ยนแปลง
3. กระบวนงาน Delete Node หน้าที่ ลบสมาชิกในลิสต์บริเวณตำแหน่งที่ต้องการข้อมูล นำเข้า ข้อมูลและตำแหน่งผลลัพธ์ลิสต์ที่มีการเปลี่ยนแปลง
4. กระบวนงาน Search list หน้าที่ ค้นหาข้อมูลในลิสต์ที่ต้องการ ข้อมูลนำเข้าลิสต์ ผลลัพธ์ ค่าจริงถ้าพบข้อมูล ค่าเท็จถ้าไม่ พบข้อมูล


การบ้าน

เขียนโปรแกรมเปรียบเทียบการใช้ฟังก์ชั่น Stdio.h กับ iostream.h แต่ผลลัพธ์ออกมาต้องเหมือนกัน

#include

main()
{
char name[30];
char surname[40];
int high;
char sex[10];
printf("Name :");
scanf("%s",&name);
printf("Surame :");
scanf("%s",&surname);
printf("High :");
scanf("%d",&high);
printf("Sex :");
scanf("%s",&sex);
if(sex=="male")
{
printf("Name : %s\n",name);
printf("Surname : %s\n",surname);
printf("High : %d\n",high-100);
printf("Sex : %s\n",sex);
}
else {
printf("Name : %s\n",name);
printf("Surname : %s\n",surname);
printf("High : %d\n",high-110);
printf("Sex : %s\n",sex);
return 0;
}
}


#include
main()
{
char name[30];
char surname[40];
int high;
char sex[10];
cout<<"Name :"; cin>>name;
cout<<"Surame:"; cin>>surname;
cout<<"High :"; cin>>high;
cout<<"Sex :"; cin>>sex;
if(sex=="male")
{
cout<<"Name : "<