X

An Introduction to Programming through C++

By Prof. Abhiram G. Ranade   |   IIT Bombay
Learners enrolled: 32813
This course provides an introduction to problem solving and programming using the C++ programming language. The topics include:
  • Basic programming notions. Control flow, variables and assignments statements, conditional execution, looping, function calls including recursion. Arrays and structures. Elementary aspects of classes. Heap memory. 
  • Program design. How human beings solve problems manually. Strategies for translating manual strategies to computer programs. Organizing large programs into units such as functions and classes. Introduction to assertions and invariants.
  • Programming applications. Arithmetic on polynomials, matrices. Root finding. Sorting and searching. Design of editors and simulators, including graphical editors. Elementary animation. A rudimentary graphics system will be discussed.
  • Standard Library of C++. The string, vector and map classes.
INTENDED AUDIENCE: First and second year students in degree programs including Engineering and Science degree programs
UG/PG: UG. PGs wishing to learn C++ will also benefit.
PRE-REQUISITES: Standard XII in the Science stream
INDUSTRY SUPPORT: Basic programming is of value to all. C++ allows you to design very fast programs and access low level machine features, but at the same time its libraries provide a very high level programming model. It can be considered a modern, safer version of the C language


Summary
Course Status : Completed
Course Type : Core
Duration : 12 weeks
Category :
  • Computer Science and Engineering
Credit Points : 3
Level : Undergraduate
Start Date : 29 Jul 2019
End Date : 18 Oct 2019
Exam Date : 17 Nov 2019 IST

Note: This exam date is subjected to change based on seat availability. You can check final exam date on your hall ticket.


Page Visits



Course layout

WEEK 1:   Introduction to computers using graphics. Notions of program organization, control flow. Introduction to a repeat macro statement and its use for drawing interesting pictures. Basics of computer hardware and how numbers and other information are represented and processed on computers.
WEEK 2:   Basic data types. Variables. Assignment statement. Introduction to program design using examples such as summing infinite series. Introduction to coordinate based graphics and elementary animation. The repeat macro is used for looping.
WEEK 3-4:   Statements of C++ for conditional execution and looping. Applications such as computing mathematical functions, root finding.
WEEK 5:   Functions. Parameter passing. Pointers and references. Recursion basics.
WEEK 6: Recursive algorithms and recursive drawings. Breaking larger programs into functions. Passing functions as arguments to other functions.
WEEK 7:  Arrays. Basic array processing strategies including passing arrays to functions. Pointers. Applications illustrating use of arrays to store sets and sequences. Iterating over pairs of objects from an array. Selection sort.
WEEK 8: Use of arrays to represent textual data. Multidimensional arrays. Command line arguments. Binary search. Mergesort.
WEEK 9:  Structures. Pointers with structures. Structure examples. Basics of classes: member functions, constructors, operator overloading and
access control.
WEEK 10: Dynamic memory allocation. Basic mechanisms and pitfalls. Design of a \String" class that has automated memory management. Copy constructors and destructors. Introduction to the standard library.
WEEK 11-12: Use of the standard library in designing programs. Design of medium size programs. A miniature program for marks and ranks display. A program for gravitational simulation. A program for designing and solving resistive circuits with a graphical user interface.


Books and references

Text Book: Abhiram G. Ranade. 2018. An Introduction to Programming through C++ (1st ed.). McGraw Hill Education (India) Private Limited, Tamil Nadu, India. 
Text-book Front Page

Instructor bio


Prof. Abhiram G. Ranade is a professor of Computer Science and Engineering at IIT Bombay. He obtained a B. Tech. degree in Electrical Engineering from IIT Bombay in 1981. In 1988 he obtained a Ph.D. in Computer Science from Yale University, USA. He was an Assistant professor of Electrical Engineering and Computer Science at the University of California, Berkeley, USA during 1988-94. Since 1995 he has been a faculty member in IIT Bombay. His research interests are Algorithms, Combinatorial Optimization, Scheduling in Transportation Systems, and Programming Education. He has won Excellence in Teaching Awards of IIT Bombay in 2006-7 and 2010-11.

Course certificate

  • The course is free to enroll and learn from. But if you want a certificate, you have to register and write the proctored exam conducted by us in person at any of the designated exam centers.
  • The exam is optional for a fee of Rs 1000/- (Rupees one thousand only).
  • Date and Time of Exams: 17th November 2019 Morning session 9am to 12 noon; Afternoon Session 2pm to 5pm.
  • Registration url: Announcements will be made when the registration form is open for registrations.
  • The online registration form has to be filled and the certification exam fee needs to be paid. More details will be made available when the exam registration form is     published. If there are any changes, it will be mentioned then.
  • Please check the form for more details on the cities where the exams will be held, the conditions you agree to when you fill the form etc.

CRITERIA TO GET A CERTIFICATE
  • Average assignment score = 25% of average of best 8 assignments out of the total 12 assignments given in the course. 
  • Exam score = 75% of the proctored certification exam score out of 100
  • Final score = Average assignment score + Exam score

YOU WILL BE ELIGIBLE FOR A CERTIFICATE ONLY IF AVERAGE ASSIGNMENT SCORE >=10/25 AND EXAM SCORE >= 30/75
  • If one of the 2 criteria is not met, you will not get the certificate even if the Final score >= 40/100.
  • Certificate will have your name, photograph and the score in the final exam with the breakup.It will have the logos of NPTEL and IIT Bombay. It will be e-verifiable at nptel.ac.in/noc.
  • Only the e-certificate will be made available. Hard copies are being discontinued from July 2019 semester and will not be dispatched.


MHRD logo Swayam logo

DOWNLOAD APP

Goto google play store

FOLLOW US