Key FeaturesDevelop a deep understanding of the collections in the Swift Standard Library with this step-by-step guideDevelop native Swift data structures and algorithms for use in mobile, desktop, and server-based applicationsLearn about performance efficiency between different data structures and algorithmsBook DescriptionApples Swift language has expressive features that are familiar to those working with modern functional languages, but also provides backward support for Objective-C and Apples legacy frameworks. These features are attracting many new developers to start creating applications for OS X and iOS using Swift. Designing an application to scale while processing large amounts of data or provide fast and efficient searching can be complex, especially running on mobile devices with limited memory and bandwidth. Learning about best practices and knowing how to select the best data structure and algorithm in Swift is crucial to the success of your application and will help ensure your application is a success. Thats what this book will teach you.Starting at the beginning, this book will cover the basic data structures and Swift types, and introduce asymptotic analysis. Youll learn about the standard library collections and bridging between Swift and Objective-C collections. You will see how to implement advanced data structures, sort algorithms, work with trees, advanced searching methods, use graphs, and performance and algorithm efficiency. Youll also see how to choose the perfect algorithm for your problem.What you will learnGet to know about the basic data structures and how to use the Swift REPLUse the Swift Standard Library collections bridging to Objective-C collections, and find out about protocol-oriented programmingFind out about Swift generators and sequences, and see how to use them to implement advanced data structures such as Stack, StackList, Queue, and LinkedListImplement sorting algorithms such as Insertion Sort, Merge Sort, and Quick Sort and understand the performance trade-offs between themSee how to implement various binary trees, B-Tree, and Splay TreesPerform advanced searching methods using Red-Black trees, AVL trees, and Trie trees, and take a look at several substring search algorithmsGet to know about the data structures used in graphs and how to implement graphs such as depth-first search, breadth-first search, directed graphs, spanning tree, and shortest pathExplore algorithm efficiency and see how to measure itAbout the AuthorErik Azar is a computer scientist with over 20 years of professional experience of architecting and developing scalable, high-performance desktop, web, and mobile applications in the areas of network engineering, system management and security, and enterprise business services, having worked in diverse positions in companies ranging from startups to Fortune 500 companies. He has been developing applications on macOS and iOS since attending his first WWDC in 2007, when Apple announced the initial iPhone.Erik is an expert developer and architect for Availity, LLC, based in Jacksonville, Florida, where he works with teams to deliver software solutions in the healthcare industry.Erik has performed technical reviews for several Packt Publishing books on Java RESTful APIs and security, enjoying the experience so much he decided to write his first book for Packt Publishing.When Erik is not being a geek, he enjoys spending time with his wife, Rebecca, and his three kids, and getting out to ride his motorcycle up and down the Florida coast.Mario Eguiluz Alebicto is a software engineer with over 10 years of experience in development. He started developing software with Java, switched later to Objective-C when the first iPhone delighted the world, and now he is also working with Swift. He founded his own startup to develop mobile applications for small companies and local shops. He has developed apps for different Fortune 500 companies and also for new disrupting startups since 2011. Now, he is working as a contractor in mobile applications, while writing technical and teaching materials whenever possible.Apart from software development, Mario loves to travel, learn new things, play sports, and has considered himself a hardcore gamer since he was a child.Table of ContentsWalking Across the PlaygroundWorking with Commonly Used Data StructuresStanding on the Shoulders of GiantsSorting AlgorithmsSeeing the Forest through the TreeAdvanced Searching MethodsGraph AlgorithmsPerformance and Algorithm EfficiencyChoosing the Perfect Algorithm
Dear publishers and self-publisher, kindly be informed that UBSM & E-Sentral are now using the same publisher panel for your convenience in uploading and updating your eBook content.
If you wish to proceed to log in/ sign up, click Yes. Otherwise, kindly click the X icon to close.