I Sem (2020-21) : Programming For Problem Solving

Download as pdf or txt
Download as pdf or txt
You are on page 1of 30

I Sem(2020-21)

Programming for Problem


Solving
(CDT101)

Mr. P. R. Pardhi (Assistant Professor )


Computer Science and Engineering RCOEM,
Nagpur
COURSE CONTENTS

Unit 1. Introduction to Programming

Unit 2. C Programming Language

Unit 3. Arrays and Basic Algorithms

Unit 4. Functions and Recursion

Unit 5. Pointer and Structures

Unit 6. File Handling


TEXT BOOKS

Text Books:
1. Programming in ANSI C : E. Balguruswami McGraw Hill
2. Mastering C: K. R. Venugopal and S. R. Prasad, Tata
McGraw Hill

Reference Books:
1. Programming with C: Byron Gottfried, Schaums Outline
Series.
2. Let Us C: Yashwant Kanetkar, BPB Publication
COURSE OUTCOMES:
On successful completion of course student will learn:

1. To formulate simple algorithms for arithmetic and logical problems, translate the
algorithms to programs (in C language), test and execute the programs and correct
syntax and logical errors.

2. To implement conditional branching, iteration and recursion, to decompose a


problem into functions and synthesize a complete program using divide and conquer
approach.

3. To use arrays, pointers, structures and I/O operations for the formulation of
algorithms and programs.

4. To apply programming to solve matrix addition, multiplication problems and


searching & sorting problems.
UNIT 1

Introduction to components of a computer


system (disks, memory, processor, where a
program is stored and executed, operating
system, compilers etc.)
Idea of Algorithm : Steps to solve logical and
numerical problems. Representation of
Algorithm: Flowchart / Pseudocode with
examples.
 Arithmetic expressions and precedence
PARTS OF A COMPUTER SYSTEM:

Hardware: Electronic Devices


Software: Instructions and Computer
Programs
HARDWARE

Input : Keyboard, Mouse


System unit:
Random Access Memory (RAM)
Central Processing Unit (CPU)
Output: Monitor, Printer
Secondary Storage: Disk Drive
SOFTWARE

 Instructions for the hardware.


 Actions to be performed
 A set of instructions is called a program.
 Driving force behind the computer
 Without a program – What is a computer?
▪ Collection of Hardware
 Two purposes:
 Tell the computer what to do
 Tell other people what we want the computer
to do.
FUNCTIONAL UNITS

Arithmetic
Input and
Logic Unit

Memory

Output Control Unit

I/O Processor

Basic functional units of a computer.


MEMORY (RAM)

 Stores data and program instructions for CPU to


execute
 A program and its data must be brought to
memory before they can be executed
 Stores intermediate and final results of
processing.
 Volatile: Contents are erased when computer is
turned off or reset.
 A memory unit is an ordered sequence of bytes,
each holds eight bits. A byte is the minimum
storage unit. No two data can share or split the
same byte.
STORAGE DEVICES

Hard Drives, CDs/DVDs, Flash Drives, etc.


Non-Volatile or Permanent Storage
Programs and data are permanently stored on
storage devices and are moved to memory
when the computer actually uses them.
COMPUTER LANGUAGE

 Digital devices have two stable states, which are


referred to as zero and one by convention
 The binary number system has two digits, 0 and 1. A
single digit (0 or 1) is called a bit, short for binary
digit. A byte is made up of 8 bits.
 Binary Language: Data and instructions (numbers,
characters, strings, etc.) are encoded as binary
numbers - a series of bits (one or more bytes made
up of zeros and ones)
COMPUTER LANGUAGE (CONT.)

 Encoding and decoding of data into binary is


performed automatically by the system based on the
encoding scheme
 Encoding schemes
 Numeric Data: Encoded as binary numbers
 Non-Numeric Data: Encoded as binary numbers using
representative code
 ASCII – 1 byte per character
 Unicode – 2 bytes per character
PROGRAMMING LANGUAGES

 Computers can not use human languages, and


programming in the binary language of computers is a
very difficult, tedious process
 Therefore, most programs are written using a
programming language and are converted to the binary
language used by the computer
 Three major categories of programming languages:
 Machine Language
 Assembly Language
 High level Language
MACHINE LANGUAGE

Natural language of a particular computer


Primitive instructions built into every
computer
The instructions are in the form of binary code
Any other types of languages must be
translated down to this level
ASSEMBLY LANGUAGES

English-like Abbreviations used for operations


(Load R1, R8)
Assembly languages were developed to make
programming easier
The computer cannot understand assembly
language - a program called assembler is used
to convert assembly language programs into
machine code
HIGH LEVEL LANGUAGES

English-like and easy to learn and program


Common mathematical notation
Total Cost = Price + Tax;
area = 5 * 5 * 3.1415;
Java, C, C++, FORTRAN, VISUAL BASIC,
PASCAL
COMPILING SOURCE CODE

A program written in a high-level language is


called a source program (or source code). Since a
computer cannot understand a source program.
Program called a compiler is used to translate
the source program into a machine language
program called an object program. The object
program is often then linked with other
supporting library code before the object can be
executed on the machine.
Source File Compiler Object File Linker Excutable File

18
PROGRAMMING

 Programming – the creation of an ordered


set of instructions to solve a problem with a
computer.
 Only about 100 instructions that the
computer understands - Different programs
will just use these instructions in different
orders and combinations.
 The most valuable part of learning to
program is learning how to think about
arranging the sequence of instructions to
solve the problem or carry out the task
PROGRAMMING FUNDAMENTALS:
PUTTING THE INSTRUCTIONS TOGETHER
 Sequential Processing
 A List of Instructions
 Conditional Execution
 Ifs
 Repetition
 Looping / Repeating
 Stepwise Refinement / Top-Down Design
 Breaking Things into Smaller Pieces
 Calling Methods / Functions / Procedures /
Subroutines
 Calling a segment of code located elsewhere
 Reuse of previously coded code segment
METHODS OF PROGRAMMING

 Procedural
 Defining set of steps to transform inputs into outputs
 Translating steps into code
 Constructed as a set of procedures
 Each procedure is a set of instructions

 Object-Oriented
 Defining/utilizing objects to represent real-world entities
that work together to solve problem
 Basic O-O Programming Components
 Class
 Object/Instance
 Properties
 Methods
PROBLEM SOLVING

 The process of defining a problem, searching for relevant


information and resources about the problem, and of
discovering, designing, and evaluating the solutions for
further opportunities. Includes:
 Finding an Answer to a Question
 Figuring out how to Perform a Task
 Figure out how to Make Things Work

 Not enough to know a particular programming language…


Must be able to problem solve…
 Very desirable to be a good Problem Solver in any CIS
discipline.
FOUR STEPS OF PROBLEM SOLVING

U – Understand the Problem


D – Devise a Good Plan to Solve

I – Implement the Plan

E – Evaluate the Solution


EXAMPLE:
SOLVING MATH WORD PROBLEM

Read the Problem: Understand the


description of problem or scenario, identifying
the knowns and unkowns
Decide how to go about solving the problem:
Determine what steps need to be taken to
reach the solution
Solve the Problem: Write the solution
Test the Answer: Make sure the answer is
correct
SOLVING COMPUTING PROBLEMS

In general, when we solve a computing


problem we are taking some inputs,
processing (performing some actions on) the
inputs, and then outputting the solution or
results.
This is the classic view of computer
programming – computation as calculation.
Four steps (UDIE) can be very effective when
applied to solving computing problems
STEP 1 - UNDERSTAND THE PROBLEM

 What is the Problem to be solved? What is the


unknown? What is the condition? What is the data?
What is needed to solve the problem? What actions
need to take place?
 Identify the inputs and outputs
 Identify the processes needed to produce the outputs
from the given inputs
 Draw a figure. Introduce suitable notation.
 Isolate Principle parts of the problem.
STEP 2 - DEVISE A PLAN

Find connections between the knowns and


unknowns.
Simplify: Break the problem into smaller sub-
problems
Design a solution
Make a plan or list of actions to implement
the solution
Algorithm / Flowchart / Psuedocode
STEP 2 - DEVISE A PLAN (CONT.)
 Algorithm
A FINITE set of clear, executable steps that will
eventually terminate to produce the desired
outcome
Logical design used to solve problems – usually a
list of actions required to perform task
 Pseudocode
Written like program code but more “English Like”
and doesn’t have to conform to language syntax
 Flowchart
Diagram that visually represents the steps to be
performed to arrive at solution.
STEP 3 - IMPLEMENT THE PLAN

Implement in a Programming Language.

Carry out the plan checking the


preliminary results at each step.

Code A Little Test A lot.


STEP 4 - EVALUATE THE SOLUTION

Run the Code


Check results repeatedly and thoroughly
Use numerous test cases or data sets
Use highly varied test case, including expected
as well as and unexpected cases
Look for new solutions
Is there a better, easier, or more efficient
solution
Can other problems be solved using these
techniques?

You might also like