KEMBAR78
Problem Solving and Programming using C.pdf
Problem Solving and Programming using C
UNIT - I
Mr. T. Pradeep
Assistant Professor
Department of Computer Applications
Sri Ramakrishna College of Arts & Science, Coimbatore - 06
Introduction
•Today, in all most all spheres of our life, Computers have found
their place and many complex things have become easier to
accomplish with the aid of computers.
•Major areas where computers are put to use including Banking,
Defence, Manufacturing, Education, Medicine, Gaming etc.,
•Fundamentals of all these areas and many other kind of problems that
are to be automated.
•In order to automate the activities in all these areas - Anatomy of the
activities need to be understood and they have to be transformed into
the form, which is amenable to the computers.
Introduction
•Here problem solving tools helps to simulate or capture the behavior
of the activities.
•Problem solving tools includes:
•Algorithms,
•Flowcharts
•Psuedocode
•Next step is to implement the procedure in a programming language
•For which we study C Programming.
Steps involved in problem solving using
Computers
•The following is the sequence of steps involved in solving a problem
using computers
• Problem Definition
• Problem Analysis
• Algorithm Design
• Coding
• Testing and Debugging
• Documentation
• Maintenance
Steps involved in problem solving using
Computers
•Problem Definition:
• State the problem clearly and unambiguously and clearly understanding
of what is required for its solution
•Problem Analysis:
• Involves the identification of inputs
• Input: The data that are to be manipulated
• Output: The expected Results
• Other Additional requirements or constraints.
Steps involved in problem solving using
Computers
•Algorithm Design:
• Involved design of the procedural solution for the problem
• Step by Step Procedure to arrive at the expected outputs by giving
available inputs in the problem domain.
• If the problem is complex, we can adopt top – down design approach.
• Top – Down Approach: Given Problem is broken down repeatedly into
smaller, easily, understandable and manageable sub problems.
• The process of breaking down a given problem into sub problems is also called
stepwise refinement
• Top-Down design or stepwise refinement is the hallmark of structured
design paradigm.
Steps involved in problem solving using
Computers
• Coding:
• Algorithm designed is converted in to a program using a programming language.
• Each step in the algorithm is realized by means of one or more statements in the programming
language
• We use C program as a coding tool
• Testing and Debugging:
• Testing involves verification of the correctness of the program created.
• Testing is normally done by running the program with all types of sample data and then
observing the output.
• Debugging is the process of detecting and correction of errors in the program code like
• Syntax error
• Runtime error
• Logical Error
Steps involved in problem solving using
Computers
•Documentation:
• Documentation includes recording the general description of the program
behavior under different situations and its special features.
• Two types of Documentation:
• Technical documentation (Technical details of the program – given by programmers)
• User documentation (Instruction about usage of the program)
•Maintenance:
• Vital Step
• User requirements keeps changing so program also need to be changed
• Proper documentation makes the programmers in charge of maintanence.
Sample Program
#include <stdio.h>
#include<conio.h>
void main()
{
clrscr();
printf("Hello, World!");
getch();
}
Prime Numbers
The numbers which have only two factors, i.e. 1 and the number itself
are called prime numbers. In other words, prime numbers are divisible
by only 1 and the number itself.
1 is Neither Prime Nor Composite
Example: 2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61,
67, 71, 73, 79, 83, 89, 97.
Pseudocode
•Pseudocode is an another way of representing a algorithm
•Pseudocode consists of plain English statements and higher level
language constructs to express Conditional execution and repeated
execution.
Sequence, Selection and Iteration
•Structured programming approach is based on three fundamental
constructs.
• 1. Sequence – Serial Execution of Instructions
• 2. Selection – Conditional Execution of Instructions
• 3. Iteration – Repeated Execution of Instruction, as long as some condition is true.
•C is designed to support structured programming , it also provides these
basic language constructs.
SEQUENCE
SELECTION
ITERATION
Examples of Pseudocode
Evolution of Programming Languages
•Language is a means of Communication
•Language mainly used for Interaction
•Without Communication Languages it is tough to survive
•Computers are problem solvers: it can do variety of class
Terms
•Instruction set –often used to collectively denote the set of all the
instructions supported by a family of computers
•If a problem is solved by a computer, the problem has to be broken
down into sequence of logical steps called an algorithm
•The algorithm has to converted into an appropriate sequence of
instructions of the computer. The set of instructions thus constructed
is referred to as a program
Classification of Programming Languages
•Machine Level Languages
•Assembly Level Languages
•High Level Languages
•Fourth Generation languages
Machine Level Languages
•Machine Level Languages came into existence soon after the advent of
computers
•These languages are often called as First Generation Computers
•The alphabets of the machine level language included only two
symbols 0 and 1.
•All electronic components which make up a computer bistable in
nature. There can be either ON state or OFF state
•ON state is denoted by 1
•OFF state is denoted by 0
Machine Level Languages
• In Machine Level Language all instructions and data had to be represented by
means of possible combinations of 0s and 1s .
• General Format:
• Opcode Operands
• Opcode represents the operation to be performed over one or more
operands.
• Example
• 10001 1100 1001
• 10001 – represents the addition operation and the bit patterns are 1100
and 1001
Machine Level Languages
• Advantages:
• Fast Execution: Program written in a machine level language executes fast as it is
already in a machine understandable form and hence no need of any translation.
• Disadvantages:
• Difficulty faced by programmers: The programmer was expected to be aware of
the details of the internal architecture of computers like memory size, Word length
etc.. In addition all the numeric codes for all the instructions have to be remembered.
• Lack of readability: The programs written using machine level languages lacked
readability. Modifications of programs also became tedious.
• Machine Dependence: Many computers vary in architectural details, Different
computers will have different machine level languages. It is highly impossible to
learn the machine language of all machines in the world.
Assembly Level Languages
•Assembly Level Languages are an improvement over the MLLs.
These Languages are often called second generation languages.
•In ALLs, Symbolic words, also known as mnemonics are used in place
of numeric opcodes.
•Example of Mnemonics: ADD, SUB
•Symbolic Names: NUM1, NUM2
•Example: ADD NUM1, NUM2
Assembly Level Languages
•Usage of symbolic words and symbolic names greatly contributed to
increased degree of readability of programs.
•Limitations:
•Each Computer Family has its own assembly level language
•In order to interact with particular computer , the corresponding ALL
has to be learnt.
•Similar to MLL, programmers required to be aware of architectural
details of computers while writing programs.
Assembly Level Languages
• Instructions written in ALL are not directly understandable by computers
• Also computers do not understand symbolic words and names
• Programs written in ALL should be converted to their MLL equivalent Programs.
This is where assembler comes into picture.
• Assembler is a system software which con verts assembly language programs into
the equivalent MLL Programs.
Assembly Level Languages
• Before Converting the ALL to MLL, assembler checks for syntactic correctness of
the assembly program.
• Syntax of ALL Programs refers the grammatical rules governing the construction
of the statements.
• Advantages:
• Easy to remember mnemonic codes compared to machine code. Hence ALL
Program is easy for the programmer.
• ALL programs are readable than MLLs program
Assembly Level Languages
•Disadvantages:
• Computers cannot understand assembly Language directly and hence program
need to be translated into Machine Language using translator called
Assembler
• Similar to MLL , Even assembly language is also machine dependent.
Mnemonic codes vary from one machine to another
Higher Level Languages (HLLs)
•The higher level Languages came into existence in the third phase of
development of languages and hence these are often called third
generation languages.
•There languages eliminated the limitations encountered by both
MLL and ALL.
•Statements written in there languages are just English like sentences
and hence more comprehensible
•Programs written in one computer can be run in another with small
modifications or no modifications in the program.
Higher Level Languages (HLLs)
•High Level Language are
•BASIC
•FORTAN
•COBOL
•PASCAL
•C
•C++
•JAVA
Higher Level Languages (HLLs)
• Advantages:
• High Degree of readability
• Machine independence
• Program writing task is more problem centric than machine centric
• Programs of HLL should be converted into MLL, this is where the concept of
Compiler and Interpreter comes into Picture
• Compiler/Interpreter is defined to be a system program, which converts
HLL program into it MLL Equivalent.
• Program written in HLL is called Source Program
• Machine Code obtained after conversion is called Object Program
Higher Level Languages (HLLs)
•Each HLL has its own compiler, Similar to assembler.
•Before compiling Compiler check for syntactic correctors of the
program.
•Advantages:
•Easy of Writing
•Machine Independent
•Disadvantages:
•Need Translator like compiler or interpreter
•Take more time dude to translation
Fourth Generation Languages
•Writing in HLL requires some degree of proficiency in programming
skills, techniques of programming and data structures etc..
•Programs written in HLL are procedural in nature.
•Later a need was felt to develop languages which are non –
procedural in nature, which even used by non technical users.
•The need led to the development of 4th
Generation Languages
•Examples: DBase, FoxPro, Structured Query Language(SQL), which
are called data base languages and graphics packages , report
generators
Fourth Generation Languages
•The programs written in these languages are also need to be compiled
by corresponding language compiler.
•Advantages:
• Programming is easy , Non Technical users can use without much
programming skills
• User can specify the format of the output.
•Disadvantages:
• Less efficient compared to high level languages
LANGUAGE TRANSLATOR
•Mnemonics – Assembly Level Language
•Mathematical Operators – High Level Language
•These two languages are not understood by Computers, Hence there is
a need of Language Translator.
•A program written in Assembly Level Language is translated into
Machine Instructions by means of Language translator called
Assembler.
•Sometimes assembler produces the machine code for the same
machine in which assembler runs , it is called Assembler.
LANGUAGE TRANSLATOR
•If an assembler runs on a machine and produces the machine code for
another machine , it is called cross – assembler
Problem Solving and Programming using C.pdf

Problem Solving and Programming using C.pdf

  • 1.
    Problem Solving andProgramming using C UNIT - I Mr. T. Pradeep Assistant Professor Department of Computer Applications Sri Ramakrishna College of Arts & Science, Coimbatore - 06
  • 2.
    Introduction •Today, in allmost all spheres of our life, Computers have found their place and many complex things have become easier to accomplish with the aid of computers. •Major areas where computers are put to use including Banking, Defence, Manufacturing, Education, Medicine, Gaming etc., •Fundamentals of all these areas and many other kind of problems that are to be automated. •In order to automate the activities in all these areas - Anatomy of the activities need to be understood and they have to be transformed into the form, which is amenable to the computers.
  • 3.
    Introduction •Here problem solvingtools helps to simulate or capture the behavior of the activities. •Problem solving tools includes: •Algorithms, •Flowcharts •Psuedocode •Next step is to implement the procedure in a programming language •For which we study C Programming.
  • 4.
    Steps involved inproblem solving using Computers •The following is the sequence of steps involved in solving a problem using computers • Problem Definition • Problem Analysis • Algorithm Design • Coding • Testing and Debugging • Documentation • Maintenance
  • 5.
    Steps involved inproblem solving using Computers •Problem Definition: • State the problem clearly and unambiguously and clearly understanding of what is required for its solution •Problem Analysis: • Involves the identification of inputs • Input: The data that are to be manipulated • Output: The expected Results • Other Additional requirements or constraints.
  • 6.
    Steps involved inproblem solving using Computers •Algorithm Design: • Involved design of the procedural solution for the problem • Step by Step Procedure to arrive at the expected outputs by giving available inputs in the problem domain. • If the problem is complex, we can adopt top – down design approach. • Top – Down Approach: Given Problem is broken down repeatedly into smaller, easily, understandable and manageable sub problems. • The process of breaking down a given problem into sub problems is also called stepwise refinement • Top-Down design or stepwise refinement is the hallmark of structured design paradigm.
  • 7.
    Steps involved inproblem solving using Computers • Coding: • Algorithm designed is converted in to a program using a programming language. • Each step in the algorithm is realized by means of one or more statements in the programming language • We use C program as a coding tool • Testing and Debugging: • Testing involves verification of the correctness of the program created. • Testing is normally done by running the program with all types of sample data and then observing the output. • Debugging is the process of detecting and correction of errors in the program code like • Syntax error • Runtime error • Logical Error
  • 8.
    Steps involved inproblem solving using Computers •Documentation: • Documentation includes recording the general description of the program behavior under different situations and its special features. • Two types of Documentation: • Technical documentation (Technical details of the program – given by programmers) • User documentation (Instruction about usage of the program) •Maintenance: • Vital Step • User requirements keeps changing so program also need to be changed • Proper documentation makes the programmers in charge of maintanence.
  • 9.
    Sample Program #include <stdio.h> #include<conio.h> voidmain() { clrscr(); printf("Hello, World!"); getch(); }
  • 23.
    Prime Numbers The numberswhich have only two factors, i.e. 1 and the number itself are called prime numbers. In other words, prime numbers are divisible by only 1 and the number itself. 1 is Neither Prime Nor Composite Example: 2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97.
  • 32.
    Pseudocode •Pseudocode is ananother way of representing a algorithm •Pseudocode consists of plain English statements and higher level language constructs to express Conditional execution and repeated execution.
  • 33.
    Sequence, Selection andIteration •Structured programming approach is based on three fundamental constructs. • 1. Sequence – Serial Execution of Instructions • 2. Selection – Conditional Execution of Instructions • 3. Iteration – Repeated Execution of Instruction, as long as some condition is true. •C is designed to support structured programming , it also provides these basic language constructs.
  • 34.
  • 35.
  • 36.
  • 37.
  • 43.
    Evolution of ProgrammingLanguages •Language is a means of Communication •Language mainly used for Interaction •Without Communication Languages it is tough to survive •Computers are problem solvers: it can do variety of class
  • 44.
    Terms •Instruction set –oftenused to collectively denote the set of all the instructions supported by a family of computers •If a problem is solved by a computer, the problem has to be broken down into sequence of logical steps called an algorithm •The algorithm has to converted into an appropriate sequence of instructions of the computer. The set of instructions thus constructed is referred to as a program
  • 45.
    Classification of ProgrammingLanguages •Machine Level Languages •Assembly Level Languages •High Level Languages •Fourth Generation languages
  • 46.
    Machine Level Languages •MachineLevel Languages came into existence soon after the advent of computers •These languages are often called as First Generation Computers •The alphabets of the machine level language included only two symbols 0 and 1. •All electronic components which make up a computer bistable in nature. There can be either ON state or OFF state •ON state is denoted by 1 •OFF state is denoted by 0
  • 47.
    Machine Level Languages •In Machine Level Language all instructions and data had to be represented by means of possible combinations of 0s and 1s . • General Format: • Opcode Operands • Opcode represents the operation to be performed over one or more operands. • Example • 10001 1100 1001 • 10001 – represents the addition operation and the bit patterns are 1100 and 1001
  • 48.
    Machine Level Languages •Advantages: • Fast Execution: Program written in a machine level language executes fast as it is already in a machine understandable form and hence no need of any translation. • Disadvantages: • Difficulty faced by programmers: The programmer was expected to be aware of the details of the internal architecture of computers like memory size, Word length etc.. In addition all the numeric codes for all the instructions have to be remembered. • Lack of readability: The programs written using machine level languages lacked readability. Modifications of programs also became tedious. • Machine Dependence: Many computers vary in architectural details, Different computers will have different machine level languages. It is highly impossible to learn the machine language of all machines in the world.
  • 49.
    Assembly Level Languages •AssemblyLevel Languages are an improvement over the MLLs. These Languages are often called second generation languages. •In ALLs, Symbolic words, also known as mnemonics are used in place of numeric opcodes. •Example of Mnemonics: ADD, SUB •Symbolic Names: NUM1, NUM2 •Example: ADD NUM1, NUM2
  • 50.
    Assembly Level Languages •Usageof symbolic words and symbolic names greatly contributed to increased degree of readability of programs. •Limitations: •Each Computer Family has its own assembly level language •In order to interact with particular computer , the corresponding ALL has to be learnt. •Similar to MLL, programmers required to be aware of architectural details of computers while writing programs.
  • 51.
    Assembly Level Languages •Instructions written in ALL are not directly understandable by computers • Also computers do not understand symbolic words and names • Programs written in ALL should be converted to their MLL equivalent Programs. This is where assembler comes into picture. • Assembler is a system software which con verts assembly language programs into the equivalent MLL Programs.
  • 52.
    Assembly Level Languages •Before Converting the ALL to MLL, assembler checks for syntactic correctness of the assembly program. • Syntax of ALL Programs refers the grammatical rules governing the construction of the statements. • Advantages: • Easy to remember mnemonic codes compared to machine code. Hence ALL Program is easy for the programmer. • ALL programs are readable than MLLs program
  • 53.
    Assembly Level Languages •Disadvantages: •Computers cannot understand assembly Language directly and hence program need to be translated into Machine Language using translator called Assembler • Similar to MLL , Even assembly language is also machine dependent. Mnemonic codes vary from one machine to another
  • 54.
    Higher Level Languages(HLLs) •The higher level Languages came into existence in the third phase of development of languages and hence these are often called third generation languages. •There languages eliminated the limitations encountered by both MLL and ALL. •Statements written in there languages are just English like sentences and hence more comprehensible •Programs written in one computer can be run in another with small modifications or no modifications in the program.
  • 55.
    Higher Level Languages(HLLs) •High Level Language are •BASIC •FORTAN •COBOL •PASCAL •C •C++ •JAVA
  • 56.
    Higher Level Languages(HLLs) • Advantages: • High Degree of readability • Machine independence • Program writing task is more problem centric than machine centric • Programs of HLL should be converted into MLL, this is where the concept of Compiler and Interpreter comes into Picture • Compiler/Interpreter is defined to be a system program, which converts HLL program into it MLL Equivalent. • Program written in HLL is called Source Program • Machine Code obtained after conversion is called Object Program
  • 57.
    Higher Level Languages(HLLs) •Each HLL has its own compiler, Similar to assembler. •Before compiling Compiler check for syntactic correctors of the program. •Advantages: •Easy of Writing •Machine Independent •Disadvantages: •Need Translator like compiler or interpreter •Take more time dude to translation
  • 58.
    Fourth Generation Languages •Writingin HLL requires some degree of proficiency in programming skills, techniques of programming and data structures etc.. •Programs written in HLL are procedural in nature. •Later a need was felt to develop languages which are non – procedural in nature, which even used by non technical users. •The need led to the development of 4th Generation Languages •Examples: DBase, FoxPro, Structured Query Language(SQL), which are called data base languages and graphics packages , report generators
  • 59.
    Fourth Generation Languages •Theprograms written in these languages are also need to be compiled by corresponding language compiler. •Advantages: • Programming is easy , Non Technical users can use without much programming skills • User can specify the format of the output. •Disadvantages: • Less efficient compared to high level languages
  • 60.
    LANGUAGE TRANSLATOR •Mnemonics –Assembly Level Language •Mathematical Operators – High Level Language •These two languages are not understood by Computers, Hence there is a need of Language Translator. •A program written in Assembly Level Language is translated into Machine Instructions by means of Language translator called Assembler. •Sometimes assembler produces the machine code for the same machine in which assembler runs , it is called Assembler.
  • 61.
    LANGUAGE TRANSLATOR •If anassembler runs on a machine and produces the machine code for another machine , it is called cross – assembler