CMPE13 Cyrus Bazeghi Chapter 19 Data Structures. CMPE13 19-2 Data Structures A data structure is a particular organization of data in memory. –We want.

Slides:



Advertisements
Similar presentations
Pointers.
Advertisements

Dynamic Allocation and Linked Lists. Dynamic memory allocation in C C uses the functions malloc() and free() to implement dynamic allocation. malloc is.
Linked Lists.
Singly Linked List BTECH, EE KAZIRANGA UNIVERSITY.
Computer Programming for Engineering Applications ECE 175 Intro to Programming.
Dynamic memory allocation
An introduction to pointers in c
Dynamic Memory Allocation in C.  What is Memory What is Memory  Memory Allocation in C Memory Allocation in C  Difference b\w static memory allocation.
C Structures and Memory Allocation There is no class in C, but we may still want non- homogenous structures –So, we use the struct construct struct for.
1 Structures. 2 User-Defined Types C provides facilities to define one’s own types. These may be a composite of basic types ( int, double, etc) and other.
Introduction to Linked Lists In your previous programming course, you saw how data is organized and processed sequentially using an array. You probably.
Programming and Data Structure
Unions The storage referenced by a union variable can hold data of different types subject to the restriction that at any one time, the storage holds data.
What is a pointer? First of all, it is a variable, just like other variables you studied So it has type, storage etc. Difference: it can only store the.
Spring 2005, Gülcihan Özdemir Dağ Lecture 12, Page 1 BIL104E: Introduction to Scientific and Engineering Computing, Spring Lecture 12 Outline 12.1Introduction.
Linked Lists
More on Dynamic Memory Allocation Seokhee Jeon Department of Computer Engineering Kyung Hee University 1 Illustrations, examples, and text in the lecture.
1 1 Lecture 4 Structure – Array, Records and Alignment Memory- How to allocate memory to speed up operation Structure – Array, Records and Alignment Memory-
Chapter 19 Data Structures. Copyright © The McGraw-Hill Companies, Inc. Permission required for reproduction or display Data Structures A data structure.
Linked Lists Chained nodes of information create what are called linked lists, with each node providing a link to the next node. A useful feature of linked.
Chapter 12 C Data Structures Acknowledgment The notes are adapted from those provided by Deitel & Associates, Inc. and Pearson Education Inc.
C o n f i d e n t i a l Developed By Nitendra NextHome Subject Name: Data Structure Using C Title: Overview of Data Structure.
Chapter 19 Data Structures Data Structures A data structure is a particular organization of data in memory. We want to group related items together.
Prof. amr Goneid, AUC1 CSCE 110 PROGRAMMING FUNDAMENTALS WITH C++ Prof. Amr Goneid AUC Part 10. Pointers & Dynamic Data Structures.
Chapter 12 Data Structure Associate Prof. Yuh-Shyan Chen Dept. of Computer Science and Information Engineering National Chung-Cheng University.
CMPSC 16 Problem Solving with Computers I Spring 2014 Instructor: Lucas Bang Lecture 15: Linked data structures.
2 Preliminaries Options for implementing an ADT List Array has a fixed size Data must be shifted during insertions and deletions Linked list is able to.
CS 11 C track: lecture 5 Last week: pointers This week: Pointer arithmetic Arrays and pointers Dynamic memory allocation The stack and the heap.
 2007 Pearson Education, Inc. All rights reserved C Data Structures.
Chapter 19 Data Structures. Copyright © The McGraw-Hill Companies, Inc. Permission required for reproduction or display Data Structures A data structure.
17. ADVANCED USES OF POINTERS. Dynamic Storage Allocation Many programs require dynamic storage allocation: the ability to allocate storage as needed.
1 C - Memory Simple Types Arrays Pointers Pointer to Pointer Multi-dimensional Arrays Dynamic Memory Allocation.
Pointers and Arrays Beyond Chapter Pointers and Arrays What are the real differences? Pointer Holds the address of a variable Can be pointed.
Stack and Heap Memory Stack resident variables include:
ECE 103 Engineering Programming Chapter 47 Dynamic Memory Alocation Herbert G. Mayer, PSU CS Status 6/4/2014 Initial content copied verbatim from ECE 103.
Dynamic Memory Allocation. Domain A subset of the total domain name space. A domain represents a level of the hierarchy in the Domain Name Space, and.
Page 1 Data Structures in C for Non-Computer Science Majors Kirs and Pflughoeft Dynamic Memory Allocation Suppose we defined the data type: struct custrec.
Pointers: Basics. 2 What is a pointer? First of all, it is a variable, just like other variables you studied  So it has type, storage etc. Difference:
Chapter 19 Data Structures. Copyright © The McGraw-Hill Companies, Inc. Permission required for reproduction or display Data Structures A data structure.
Introduction to Data Structures Systems Programming Concepts.
1 Chapter 16 Linked Structures Dale/Weems. 2 Chapter 16 Topics l Meaning of a Linked List l Meaning of a Dynamic Linked List l Traversal, Insertion and.
Chapter 17 Free-Space Management Chien-Chung Shen CIS, UD
Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Slide
APS105 Lists. Structures Arrays allow a collection of elements –All of the same type How to collect elements of different types? –Structures; in C: struct.
+ Dynamic memory allocation. + Introduction We often face situations in programming where the data is dynamics in nature. Consider a list of customers.
Computer Programming for Engineering Applications ECE 175 Intro to Programming.
ENEE150 – 0102 ANDREW GOFFIN Dynamic Memory. Dynamic vs Static Allocation Dynamic  On the heap  Amount of memory chosen at runtime  Can change allocated.
MORE POINTERS Plus: Memory Allocation Heap versus Stack.
Sudeshna Sarkar, CSE, IIT Kharagpur1 Structure and list processing Lecture
1 Linked List. Outline Introduction Insertion Description Deletion Description Basic Node Implementation Conclusion.
Data Structure & Algorithms
© Copyright 1992–2004 by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. Linked Lists Outline Introduction Self-Referential Structures.
Linked Lists Chapter Introduction To The Linked List ADT Linked list: set of data structures (nodes) that contain references to other data structures.
Prof. Amr Goneid, AUC1 CSCE 210 Data Structures and Algorithms Prof. Amr Goneid AUC Part R2. Elementary Data Structures.
DYNAMIC MEMORY ALLOCATION. Disadvantages of ARRAYS MEMORY ALLOCATION OF ARRAY IS STATIC: Less resource utilization. For example: If the maximum elements.
C Structures and Memory Allocation
Dynamic Allocation Review Structure and list processing
Lectures linked lists Chapter 6 of textbook
12 C Data Structures.
Chapter 19 Data Structures
Chapter 19 Data Structures
Chapter 19 Data Structures
Chapter 19 Data Structures
Chapter 16 Linked Structures
Data Structures & Algorithms
C Structures and Memory Allocation
Module 13 Dynamic Memory.
Midterm 1 Review CS270 - Spring Semester 2019.
Chapter 19 Data Structures -struct -dynamic memory allocation
Chapter 16 Pointers and Arrays
Presentation transcript:

CMPE13 Cyrus Bazeghi Chapter 19 Data Structures

CMPE Data Structures A data structure is a particular organization of data in memory. –We want to group related items together. –We want to organize these data bundles in a way that is convenient to program and efficient to execute. An array is one kind of data structure. In this chapter, we look at two more: struct – directly supported by C linked list – built from struct and dynamic allocation

CMPE Structures in C A struct is a mechanism for grouping together related data items of different types. –Recall that an array groups items of a single type. Example: We want to represent an airborne craft: char flightNum[7]; int altitude; int longitude; int latitude; int heading; double airSpeed; We can use a struct to group these data together for each plane.

CMPE Defining a Struct We first need to define a new type for the compiler and tell it what our struct looks like. struct flightType { char flightNum[7]; /* max 6 characters */ int altitude; /* in meters */ int longitude; /* in tenths of degrees */ int latitude; /* in tenths of degrees */ int heading; /* in tenths of degrees */ double airSpeed; /* in km/hr */ }; This tells the compiler how big our struct is and how the different data items (“members”) are laid out in memory. But it does not allocate any memory.

CMPE Declaring and Using a Struct To allocate memory for a struct, we declare a variable using our new data type. struct flightType plane; Memory is allocated, and we can access individual members of this variable: plane.airSpeed = 800.0; plane.altitude = 10000; A struct’s members are laid out in the order specified by the definition. plane.flightNum[0] plane.flightNum[6] plane.altitude plane.longitude plane.latitude plane.heading plane.airspeed

CMPE Defining and Declaring at Once You can both define and declare a struct at the same time. struct flightType { char flightNum[7]; /* max 6 characters */ int altitude; /* in meters */ int longitude; /* in tenths of degrees */ int latitude; /* in tenths of degrees */ int heading; /* in tenths of degrees */ double airSpeed; /* in km/hr */ } maverick; And you can use the flightType name to declare other structs: struct flightType iceMan;

CMPE typedef C provides a way to define a data type by giving a new name to a predefined type. Syntax: typedef ; Examples: typedef int Color; typedef struct flightType Flight; typedef struct ab_type { int a; double b; } ABGroup;

CMPE Using typedef This gives us a way to make code more readable by giving application-specific names to types. Color pixels[500]; Flight plane1, plane2; Typical practice: Put typedef’s into a header file, and use type names in main program. If the definition of Color/Flight changes, you might not need to change the code in your main program file.

CMPE Array of Structs Can declare an array of structs: Flight planes[100]; Each array element is a struct (7 words, in this case). To access member of a particular element: planes[34].altitude = 10000; Because the [] and. operators are at the same precedence, and both associate left-to-right, this is the same as: (planes[34]).altitude = 10000;

CMPE Pointer to Struct We can declare and create a pointer to a struct: Flight *planePtr; planePtr = &planes[34]; To access a member of the struct addressed by PlanePtr: (*planePtr).altitude = 10000; Because the. operator has higher precedence than *, this is NOT the same as: *planePtr.altitude = 10000;

CMPE Pointer to Struct C provides special syntax for accessing a struct member through a pointer: planePtr->altitude = 10000; This makes it less likely to mess up.

CMPE Passing Structs as Arguments Unlike an array, a struct is always passed by value into a function. This means the struct members are copied to the function’s activation record, and changes inside the function are not reflected in the calling routine’s copy. Most of the time, you’ll want to pass a pointer to a struct. int Collide(Flight *planeA, Flight *planeB) { if (planeA->altitude == planeB->altitude) {... } else return 0; }

CMPE Dynamic Allocation Suppose we want our weather program to handle a variable number of planes – as many as the user wants to enter. –We can’t allocate an array, because we don’t know the maximum number of planes that might be required. –Even if we do know the maximum number, it might be wasteful to allocate that much memory because most of the time only a few planes’ worth of data is needed. Solution: Allocate storage for data dynamically, as needed.

CMPE malloc The Standard C Library provides a function for allocating memory at run-time: malloc. void *malloc(int numBytes); It returns a generic pointer ( void* ) to a contiguous region of memory of the requested size (in bytes). The bytes are allocated from a region in memory called the heap. –The run-time system keeps track of chunks of memory from the heap that have been allocated.

CMPE Using malloc To use malloc, we need to know how many bytes to allocate. The sizeof operator asks the compiler to calculate the size of a particular type. planes = malloc(n * sizeof(Flight)); We also need to change the type of the return value to the proper kind of pointer – this is called “casting.” planes = (Flight*) malloc(n* sizeof(Flight));

CMPE Example int airbornePlanes; Flight *planes; printf(“How many planes are in the air?”); scanf(“%d”, &airbornePlanes); planes = (Flight*) malloc(sizeof(Flight) * airbornePlanes); if (planes == NULL) { printf(“Error in allocating the data array.\n”);... } planes[0].altitude =... If allocation fails, malloc returns NULL. Note: Can use array notation or pointer notation.

CMPE free Once the data is no longer needed, it should be released back into the heap for later use. This is done using the free function, passing it the same address that was returned by malloc. void free(void*); If allocated data is not freed, the program might run out of heap memory and be unable to continue.

CMPE The Linked List Data Structure A linked list is an ordered collection of nodes, each of which contains some data, connected using pointers. –Each node points to the next node in the list. –The first node in the list is called the head. –The last node in the list is called the tail. Node 0Node 1Node 2 NULL

CMPE Linked List vs. Array A linked list can only be accessed sequentially. To find the 5 th element, for instance, you must start from the head and follow the links through four other nodes. Advantages of linked list: –Dynamic size –Easy to add additional nodes as needed –Easy to add or remove nodes from the middle of the list (just add or redirect links) Advantage of array: –Can easily and quickly access arbitrary elements

CMPE Example: Car Lot Create an inventory database for a used car lot. Support the following actions: –Search the database for a particular vehicle. –Add a new car to the database. –Delete a car from the database. The database must remain sorted by vehicle ID. Since we don’t know how many cars might be on the lot at one time, we choose a linked list representation.

CMPE Car data structure Each car has the following characterics: vehicle ID, make, model, year, mileage, cost. Because it’s a linked list, we also need a pointer to the next node in the list: typedef struct carType Car; struct carType { int vehicleID; char make[20]; char model[20]; int year; int mileage; double cost; Car *next; /* ptr to next car in list */ }

CMPE Scanning the List Searching, adding, and deleting all require us to find a particular node in the list. We scan the list until we find a node whose ID is >= the one we’re looking for. Car *ScanList(Car *head, int searchID) { Car *previous, *current; previous = head; current = head->next; /* Traverse until ID >= searchID */ while ((current!=NULL) && (current->vehicleID next; } return previous; }

CMPE Adding a Node Create a new node with the proper info. Find the node (if any) with a greater vehicleID. “Splice” the new node into the list: Node 0Node 1Node 2 NULL new node

CMPE Excerpts from Code to Add a Node newNode = (Car*) malloc(sizeof(Car)); /* initialize node with new car info */... prevNode = ScanList(head, newNode->vehicleID); nextNode = prevNode->next; if ((nextNode == NULL) || (nextNode->vehicleID != newNode->vehicleID)) prevNode->next = newNode; newNode->next = nextNode; } else { printf(“Car already exists in database.”); free(newNode); }

CMPE Deleting a Node Find the node that points to the desired node. Redirect that node’s pointer to the next node (or NULL). Free the deleted node’s memory. Node 0Node 1Node 2 NULL

CMPE Excerpts from Code to Delete a Node printf(“Enter vehicle ID of car to delete:\n”); scanf(“%d”, vehicleID); prevNode = ScanList(head, vehicleID); delNode = prevNode->next; if ((delNode != NULL) && (delNode->vehicleID == vehicleID)) prevNode->next = delNode->next; free(delNode); } else { printf(“Vehicle not found in database.\n”); }

CMPE Building on Linked Lists The linked list is a fundamental data structure. –Dynamic –Easy to add and delete nodes The concepts described here will be helpful when learning about more elaborate data structures: –Trees –Hash Tables –Directed Acyclic Graphs –...