Rutgers, The State University of New Jersey
Camden Undergraduate
 
About the University
Undergraduate Education in Camden
Degree Requirements
Liberal Arts Colleges
Camden College of Arts and Sciences
University College-Camden
Programs, Faculty, and Courses
Course Notation Information
Availability of Majors
Accounting 010
Africana Studies 014
American History 512
American Literature 352
Anthropology 070
Art 080
Art History 082
Arts and Sciences 090 (Interdisciplinary Courses)
Astronomy 100
Biochemistry 115
Biology 120
Biology, Computational and Integrative 121
Business Administration 135
Business Law 140
Chemistry (Biochemistry 115, Chemistry 160)
Childhood Studies 163
Computer Science 198
Major Requirements: CCAS and UCC
Bachelor of Science (B.S.) in Computer Science
Bachelor of Arts (B.A.) in Computer Science
Minor Requirements: CCAS and UCC
Departmental Honors Program
Joint B.S./M.S. Degree Program
Courses
Criminal Justice 202
Dance 203
Digital Studies 209
Economics 220
Engineering Transfer 005
English and Communication (Communication 192, English Literature 350, American Literature 352, Film 354, Journalism 570, Linguistics 615, Rhetoric 842, Writing 989)
Finance 390
Forensic Science 412
French 420
Gender Studies 443
Geology 460
German 470
Global Studies 480
Health Sciences 499
History (Historical Methods and Research 509; European History 510; American History 512; African, Asian, Latin American, and Comparative History 516)
Honors College 525
Human Resource Management 533
Individualized Majors and Minors 555
Journalism 570
Latin American and Latino Studies (LALS) Minor
Law
Learning Abroad
Liberal Studies 606
Linguistics 615
Management 620
Management Science and Information Systems 623
Marketing 630
Mathematical Sciences (Mathematics 640, Statistics 960)
Medicine, Dentistry, and Veterinary Medicine
Museum Studies 698
Music 700, 701
Pharmacy 720
Philosophy and Religion 730, 840
Physics 750
Political Science 790
Psychology 830
Religion 840
Reserve Officer Training Programs
Social Work 910
Sociology (920), Anthropology (070), and Criminal Justice (202)
Spanish 940
Statistics 960
Teacher Education 964
Theater Arts (Dance 203, Theater Arts 965)
World Languages and Cultures (French 420, German 470, Global Studies 480, Spanish 940)
Urban Studies 975
Visual, Media, and Performing Arts (Art 080; Art History 082; Museum Studies 698; Music 700, 701; Theater Arts 965)
Rutgers School of Business-Camden
School of Nursing-Camden
Academic Policies and Procedures
Divisions of the University
Camden Newark New Brunswick/Piscataway
Catalogs
  Camden Undergraduate Catalog 2023-2025 Liberal Arts Colleges Programs, Faculty, and Courses Computer Science 198 Courses  

Courses


All computer science prerequisites (i.e., courses beginning with 50:198) must be satisfied with a grade of C or better.
50:198:111 Programming Fundamentals (R) (4) Fundamental concepts of structured programming and algorithmic problem solving: primitive data types, control structures, functions and parameter passing, top-down design, arrays, files, and the mechanics of compiling, running, testing, and debugging programs. These concepts will be taught using the high-level language Python. Prerequisite: 50:640:113 or 115, or by placement.
50:198:113 Object-Oriented Programming (R) (3) Principles of object-oriented program design and advanced algorithmic problem solving illustrated through an object-oriented language. Topics include encapsulation and information hiding; classes, subclasses, and inheritance; polymorphism; class hierarchies, and the creation, implementation, and reuse of APIs (application programming interfaces). Extensive practice with designing and implementing object-oriented programs, especially using elementary data structures such as stacks, queues, and heaps.
Prerequisite: 50:198:111. Corequisite: 50:640:121 or 118.
50:198:171 Mathematical Foundations of Computer Science (R) (3) Sets, relations, and functions; pigeon-hole principle; cardinality, countability, and uncountability; propositional and predicate logic; universal and existential quantification; proof techniques: formal proofs using counterexample, contraposition, contradiction, and induction; recursive definitions; basic counting: inclusion-exclusion, arithmetic, geometric progressions, and summations; properties of special functions such as logarithms, exponentials, and factorials; permutations and combinations, solving recurrences; graphs and trees; basic discrete probability. Prerequisite: 50:640:113 or 115.
50:198:211 C and Systems Programming (R) (3) Introduction to programming in the C language with an emphasis on its use in writing low-level systems programs. Topics will include coverage of standard C programming idioms, especially with macros and memory management; introduction to programming with the Unix shell and POSIX system calls; and experience with testing and code maintenance using standard tools like debuggers and code revisioning systems. Prerequisites: 50:198:113 and (50:640:121 or 130).
50:198:213 Data Structures (R) (3) Basic algorithmic analysis: asymptotic notation (Big-Oh, little-oh, and Theta) for estimating the complexity of a problem, using recurrence relations to analyze the complexity of recursive algorithms. Tree-based data structures: binary search trees, heaps, and balanced search trees; hash functions and hash tables; abstract dictionaries; using data structures to implement basic algorithms (such as searching, sorting, and depth- and breadth-first search in graphs; data compression). Prerequisites: 50:198:113 and 171 and (50:640:121 or 118).
50:198:325 Java Applications (3) Java class hierarchy and inheritance; applications and applets; graphical user interfaces, exception handling, input/output; multithreading, multimedia, and networking. Prerequisites: 50:198:113 and 213.
50:198:331 Introduction to Computer Organization (3) Elementary digital logic; machine-level representation of data; assembly-level machine organization: the von Neumann machine with its fetch-decode-execute cycle, instruction sets, and assembly language programming; addressing modes; subroutine calls and returns; I/O and interrupts; memory systems: hierarchy, organization, and operations. Prerequisite: 50:198:113. Corequisite: 50:198:211.
50:198:335 Cybersecurity Fundamentals (3) Cybersecurity Fundamentals will cover basic topics in cybersecurity related to risk management and mitigation, encryption, network security, wireless security, social engineering, malware and ransomware, operating system security, defense in depth, secure software life cycle, and penetration testing. Students will complete this course with a basic working knowledge of these topics, as well as a working understanding of the current cybersecurity threat landscape. Prerequisite: 50:198:211.
50:198:341 Operating Systems (3) Comprehensive, hands-on coverage of operating system principles, design, and implementation. Topics include kernel development; process concurrency issues such as starvation, mutual exclusion, deadlock avoidance, concurrency models and mechanisms, producer-consumer problems, and synchronization; scheduling policies and algorithms for preemptive and nonpreemptive scheduling; memory management and analysis of paging and segmentation policies; and file systems. Prerequisites: 50:198:113 and 211. Corequisite: 50:198:331.
50:198:355 Secure Coding (3) Introduction to some of the most common forms of security vulnerabilities a software engineer must be aware of when designing, implementing, and verifying software systems. The course will review the most common form of defects, bugs, and logic flaws that can become security vulnerabilities, cite real-world examples of their exploitation, and provide students with a working knowledge of how to mitigate against such exploitations, including the use of static code analysis tools. Prerequisites: 50:198:211 and 331.
50:198:371 Design and Analysis of Algorithms (3) Algorithm design techniques: divide-and-conquer, greedy method, dynamic programming, backtracking, and branch-and-bound. Advanced data structures, graph algorithms,  and algebraic algorithms. Complexity analysis, complexity classes, and NP-completeness. Introduction to approximation algorithms and parallel algorithms. Prerequisites: 50:198:171 and 213.
50:198:414 Artificial Intelligence (3) The objective of this course is to become familiar with the fundamentals of Artificial Intelligence. This course will provide students with an understanding of main concepts of Artificial Intelligence (AI) needed for the implementation and performance of intelligent agents/programs and to understand their applications. It focuses on the theory and algorithms underlying AI, including heuristic approaches and advanced search, inference in first order logic, knowledge representation, probabilistic reasoning, and Bayesian belief networks. Prerequisites: 50:640:121 or 130 and 50:198:213.
50:198:423 Software Engineering (3) Principles and techniques for the design and construction of reliable, maintainable, and useful software systems. Software life cycle, requirements specifications, and verification and validation issues. Implementation strategies (e.g., top-down, bottom-up, teams), support for reuse, and performance improvement. A treatment of human factors and user interfaces included. Prerequisites: 50:198:113 and 171.
50:198:441 Distributed and Cloud Computing (3) This course introduces the concepts, models, implementations, and applications of cloud computing and distributed systems. Topics will include distributed architectures, cloud architectures, technologies, services, and security. The course will provide students hands-on experience implementing core cloud services and will allow for a more in-depth exploration with a significant semester project. Prerequisites: 50:198:171 and 50:198:331.
50:198:447 Network Security (3) This course provides in-depth instruction on network security methods and technologies. Today, data is typically connected to networks, which then may be connected to the internet. Given the wide access that data may have as a result, it is critical that network security methods are used to limit access to legitimate users. This is accomplished through network design, access control policies, and network technology. This course will provide instruction on how these items are used to protect information. This includes the following topics: firewalls, intrusion detection and prevention, virtual private networks, proxies, remote access protections, data loss prevention systems, network and security management systems. Prerequisite: 50:198:331.
50:198:451 Database Systems (3) Relational database theory and practice, including database design. Database concepts, relational algebra, data integrity, query languages, and views. Introduction to object-oriented databases. Application project with a practical database management system. Prerequisites: 50:198:113 and 171.
50:198:454 Machine Learning (3) This course provides an overview of machine learning and data mining with a focus on the theory and algorithms underlying a range of tasks including data collection and mining, statistical learning theory and underlying probability theory, decision trees, supervised and unsupervised learning, classification, regression and clustering, deep learning, and the derivation of practical solutions using predictive analytics. The course will include machine learning applications in different fields such as bioinformatics and big data analysis. Prerequisites: (50:640:122 or 124) and 50:198:213.
50:198:456 Computer Graphics (3) Graphics systems and imaging principles, graphics programming using packages like OpenGL, input devices and interactive techniques, animation techniques, geometric transformations and modeling in two and three dimensions, viewing in 2D and 3D, lighting and shading, fundamental graphics algorithms (such as clipping, hidden surface removal, etc.) Prerequisites: 50:198:213.
50:198:461 Optimization Methods (3) This course introduces various methods based on linear programming to solve discrete optimization problems. The topics covered in the course include an introduction to linear programming (LP), network flows, and application of LP-based techniques to solve various optimization problems. Prerequisites: (50:640:121 or 118), 50:640:250, and 50:198:213.
50:198:462 Big Data Algorithms (3) Study of algorithmic techniques and modeling frameworks that facilitate the analysis of massively large amounts of data. Introduction to information retrieval, streaming algorithms, and analysis of web searches and crawls. Prerequisite: 50:198:213.
50:198:467 Applied Probability (3) An introduction to probability theory and the modeling and analysis of probabilistic systems with emphasis on applications in computer science, engineering, and data science. Probabilistic models, conditional probability. Discrete and continuous random variables. Expectation and conditional expectation. Limit theorems. Bernoulli and Poisson processes. Markov chains. Bayesian estimation and hypothesis testing. Elements of statistical inference. Prequisite: 50:198:171 and (50:640:122 or 124).
50:198:473 Computational Geometry (3) Algorithms and data structures for geometric problems that arise in various applications, such as computer graphics, CAD/CAM, robotics, and geographical information systems (GIS). Topics include point location, range searching, intersection, decomposition of polygons, convex hulls, Voronoi diagrams, line arrangements, and Delaunay triangulations. Prerequisites: 50:198:171 and 213.
50:198:475 Cryptography and Computer Security (3) Secret-key cryptography, public-key cryptography, key agreement, secret sharing, digital signatures, message and user authentication, one-way functions, key management; attacks; practical applications to computer and communications security. Prerequisites: 50:198:113 and 171.
50:198:476 Theory of Computation (3) Formal languages, automata and computability; regular languages and finite-state automata; context-free grammars and languages; pushdown automata; the Church-Turing theses; Turing machines; decidability and undecidability. Prerequisites: 50:198:171 and 213.
50:198:491,492 Special Topics in Computer Science (3,3) In-depth study of areas not covered in regular curriculum. Topics vary from semester to semester.
Prerequisite: As announced or permission of instructor.
50:198:493 Senior Design Project (3) Design, implementation, and demonstration of a significant software and/or hardware project. Project proposals must be submitted, approved, and supervised by a faculty member. Part of the project time is used to discuss such issues as the historical and social context of computing, responsibilities of the computing professional, risks and liabilities, and intellectual property. This course is intended for computer science majors in their senior year who have completed at least three 300- or 400-level courses in computer science. Prerequisite: Approval by department.
50:198:494 Independent Study (BA) Individual study under the supervision of a computer science faculty member; intended to provide an opportunity to investigate areas not covered in regular courses. Prerequisite: Permission of instructor.
50:198:495-496 Honors Program in Computer Science (BA,BA) A program of readings and guided research in a topic proposed by the student, culminating in an honors thesis presented to the departmental faculty for approval. Prerequisite: Approval by department.
50:198:497 Computer Science Internship (BA) The practical application of computer science knowledge and skills through an approved internship in a sponsoring organization. Arrangements for the internship must be agreed upon by the sponsoring organization and approved by the department before the beginning of the semester in which the internship is conducted. Students should consult the department for detailed instructions before registering for this course. Prerequisite: Approval by department.
 
For additional information, contact RU-info at 848-445-info (4636) .
Comments and corrections to: One Stop Student Services Center.

© 2024 Rutgers, The State University of New Jersey. All rights reserved.
Catalogs Home