Discrete Structure CS 203 Introduction Lecture 1 2 Computer science Computer science or computing science (abbreviated CS or CompSci) is the scientific approach to computation and its applications. A computer scientist specializes in the theory of computation and the design of computers or computational systems. 3 CS Branches Its subfields can be divided into a variety of theoretical and practical disciplines. computational complexity theory (which explores the fundamental properties of computational problems), are highly abstract 4 CS Branches computer graphics emphasize real-world applications. programming language theory considers various approaches to the description of computation, whilst the study of computer programming itself investigates various aspects of the use of programming language and complex systems. Human-computer interaction considers the challenges in making computers and computations useful, usable, and universally accessible to humans. 5 CS Mobile Computing Computer Architecture Natural Language Processing Robotics Computer Networks Software Engineering Database Administration Data Warehousing and Data Mining Game Development 6 CS Concurrent, Parallel, and Distributed Systems Communications and Security Web Science Artificial Intelligence User Interface Engineering Image Processing Computer Aided Engineering 7 CS Bioinformatics Medical Informatics Cryptography Algorithm Analysis Simulation and Modeling Operating Systems Performance Analysis 8 CS Career Designing and implementing software. Devising new ways to use computers(application of computer technology) Database developer & admininnstrator Game programmer Graphic design 9 CS Career System administrator Software tester Web design & developer & administrator 10 Lecture 1 11 Lecture 1 12 Lecture 1 13 CS Courses Programming (C & C+ & Java) Graphics AI Networks Database Data structure Operating system Lecture 1 15 CS Courses Theory of Computation Digital circuits Algorithms Etc 100 معفى من مادة س 16 CS Staff د ياسر فؤاد د احمد يونس د اسالم ثروت د احمد شريف د خالد محمد د اشرف سعيد 17 Lecture 1 CS Staff مروة عابدين نرمين محمود يسر حسين سعيد محمد احمد صالح شيماء المرسى 18 Lecture 1 CS Staff نيللى سارة احمد عبد القادر اية هدير ايمان خالد 19 Lecture 1 CS labs معملين مبنى أ الدور االول معمل سى كاب معمل د 20 Lecture 1 Class web page, e-mail http://www.alexu.edu.eg/index.php/ar/2011-09-26-07-0634/25-staff-courses/computer-science/3791-discreet-cs203 Alexandria university site مواقع المقررات الدراسية E-mail y.fouad@sci.alexu.edu.eg Problems solved using Discrete Math How many secure passwords? Probability of winning Texas Hold’em? How can I encrypt a message? Shortest paths between two cities using public transportation? How many steps required to sort 10,000 numbers? Is this algorithm correct? How to design a circuit that multiply two integers? Course content very approximately in temporal order Logic and Reasoning Sets, Functions, Sequences and Sums Number Theory, Algorithms, the Integers Induction and Recursion Counting, Relations Graph Theory Overall course context First course in CS Major Students will have taken CS102, CS201 Broad range of mathematical background of entering students Goals of the course Formalism for later study Learn how to do a mathematical argument for CS Course Overview Discrete Structure is essentially that branch of Computer science & Mathematics. As computers are discrete object operating one jumpy, discontinuous step at a time, Discrete Struct is the right framework for describing precisely Computer Science concepts. 25 Quick Overview Discrete Sturcture helps provide… …the machinery necessary for creating sophisticated algorithms …the tools for analyzing their efficiency …the means of proving their validity 26 Graph Theory Euler Paths and Circuits In order to minimize cost to the city, how should weekly garbage collection routes be designed for Detroit’s 350,000 households? Quick Overview - Topics Logic and Sets Make notions you’re already used to from programming a little more rigorous (operators) Fundamental to all mathematical disciplines Useful for digital circuits, hardware design Elementary Number Theory Get to rediscover the old reliable number and find out some surprising facts Very useful in crypto-systems 28 Quick Overview - Topics Proofs (especially induction) If you want to debug a program beyond a doubt, prove that it’s bug-free Proof-theory has recently also been shown to be useful in discovering bugs in pre-production hardware Counting and Combinatorics Compute your odds of winning lottery Important for predicting how long certain computer program will take to finish Useful in designing algorithms 29 Counting & Arranging How secure are your passwords? If your password consists of 3 letters and 3 numerals, how likely is it that someone could successfully guess the configuration? Coding Information Identification Numbers What mathematics is involved in the design of UPC codes? Grading The overall grade will be based upon 30% for homework or assignment, quiz, and lab 70% final Extra credit questions will be always available. Quick Test... Count the green squares… you will have three seconds… How many were there?