Skip to content

Latest commit

 

History

History
440 lines (366 loc) · 20.5 KB

README.md

File metadata and controls

440 lines (366 loc) · 20.5 KB

Computer Science and Engineering Roadmap and Checklist

This is the complete syllabus of Computer Science and Engineering UG.

Computer Science is divided in 4 parts

Discrete MathematicsPDF is necessary for understanding Graphs.

Table of Contents

Computer Science - 1

Digital Electronics

  • Boolean Algebra

    • Number System
    • Addition, Subtraction
    • Multiplication, Division
    • 1's, 2's compliments
    • k-maps
  • Hardware

    • Logic Gates
    • Flip-Flops and Latches
    • Adder - Subtractor
    • Encoder - Decoder
    • Multiplexer - Demultiplexer
    • Integrated Circuits
    • Printed Circuit Boards

Computer Organization and Architecture

  • Computer Organization

    • Address Bus, Data Bus
    • ROM, EPROM, RAM
    • Memory Hierarchy, Cache Memory, Virtual Memory
    • Secondary Storage
    • Programmable Logic Devices and Controllers
    • Input - Output Devices
  • Computer Architecture

    • Stack
    • Registers
    • Endianness (Big, Little)
    • Floating Point Numbers
    • Addressing Modes
    • Pipelining
    • Interrupts
    • RISC - CISC
    • aarch64, Intel_x86 / AMD64, MIPS / RISC-V (learn the differences)
    • Assembly Language (basic instructions)

Theory of Computation and Automata

Computer Science - 2

Compiler Design

  • Compiler Design
    • Lexical analysis
    • Syntax analysis
    • Type Checking
    • Intermediate code generation
    • Machine code generation
    • Assembly and linking
    • Analysis and optimisation
    • Memory management
    • Interpreters
    • Golang reference specificationsIf you want to read an easy specification

Programming

Data Structures

  • Searching
    • Binary Search
    • Priority Queues
  • Sorting
    • Merge Sort
    • Quick Sort
    • Insertion Sort
    • Selection Sort
  • Graph Traversal
    • Breadth First Search
    • Depth First Search
    • Dijkstra's Algorithm
    • Bellman Ford (Cycle detection & Negative edges)
    • Shortest Paths
    • Minimum Spanning Trees
  • space-time Complexity

Artificial Intelligence

Computer Science - 3

DBMS and SQL

FCC quick commands | Graphical view

  • The Boot Process
  • Processes and Threads
    • Process Control Block
    • Dispatcher and Scheduler
  • Inter Process Communication
    • Mesage Passing
    • Shared Memory
  • Scheduling Algorithms
    • Round Robin.
    • Shortest Remaining Time First.
    • Least Recently Used.
  • Deadlocks
    • MutEx and Locks
    • Semaphores
    • Banker's Algorithm
  • Memory Management
    • Paging and Page tables
    • Segmentation
    • First Fit, Next Fit, Best Fit
    • Non-continuous Allocation
  • Virtual memory
    • Page Faults
    • Page Replacement Algorithms
    • Belady’s Anomaly
  • IO Scheduling
    • Shortest Seek Time First
    • Disk Scheduling Algorithms
  • File Systems
    • File Allocation Tables.
  • OS Security
    • Firewall
    • Malware and Antiviruses
  • Unix commands
  • Multithreading and Context Passing in Programming languages

Computer Networks

  • Layers of TCP and OSI

    • Application.
    • Presentation.
    • Session.
    • Transport.
    • Network.
    • Data.
    • Physical.
  • Flow and Congestion Control

    • Flow Control
    • Congestion Control
    • Error Control
  • Routers and Routing Algorithms

    • DHCP and static routing
    • DHCP | ICMP
    • Bellman Ford
    • Round Robin and others
  • UDP and Sockets

  • IPv4 | IPv6

  • Autonomous Systems

  • Application Layer Protocols

    • HTTP | FTP
    • DNS | SMTP
    • Email MIME Types | POP | IMAP
  • Cloud Computing

    • SAAS | PAAS | IAAS (AAS : As A Service)
    • Full and Para Virtualization : KVM/QEMU
    • Virtual Machines and Hypervisors ( Bare Metal | Hosted )
    • Clones | Snapshots | Scaling

Software Engineering

  • Software development models

    • Waterfall
    • Spiral
    • Iterative
    • Agile
  • Software Cost Estimation

  • COCOMO Model

  • Risk Management

  • Software Requirement

    • Software Requirement Specifications
    • Data Flow Diagrams
  • Software Quality

    • ISO standards 9001, 14001
    • SEICMM
    • Six Sigma
  • Software Design

    • Software Design Principles
    • Coupling and Cohesion
    • Object-Oriented Design
    • User Interface Design
  • Testing

Computer Science - 4

You will need these when you make projects

Cryptography and Network Security

Data Science and Machine Learning

Web Development

You can study Web Development from Mozilla Developer Network Website.

Not mandatory, just get the overview

After you are done with all this and want to make projects, check out Projects you can make

LICENSE

Mozilla-Public-License