DataStru Ques

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

Biyani's Think Tank

Concept based notes

Data Structure and Algorithms


(BCA Part-I)

Bhavana Sangamnerkar
M.Sc. (Comp. Prog.), PGDCA

H.O.D. Information Technology Biyani Girls College, Jaipur

Fore more detail:- http://www.gurukpo.com

Published by :

Think Tanks Biyani Group of Colleges

Concept & Copyright :

Biyani Shikshan Samiti


Sector-3, Vidhyadhar Nagar, Jaipur-302 023 (Rajasthan) Ph. : 0141-2338371, 2338591-95 l Fax : 0141-2338007 E-mail : [email protected] Website : www.biyanithinktank.com; www.biyanicolleges.org

First Edition : 2009

Price :

While every effort is taken to avoid errors or omissions in this Publication, any mistake or omission that may have crept in is not intentional. It may be taken note of that neither the publisher nor the author will be responsible for any damage or loss of any kind arising to anyone in any manner on account of such errors and omissions.

Type Setted by : Biyani College Printing Department

Fore more detail:- http://www.gurukpo.com

Preface

am glad to present this book, especially designed to serve the needs of the students. The book has been written keeping in mind the general weakness in understanding the fundamental concept of the topic. The book is self-explanatory and adopts the Teach Yourself style. It is based on question-answer pattern. The language of book is quite easy and understandable based on scientific approach. This book is written as exam based study material pattern, how a student should answer for a question, how an examiner wants from student side, how can students get more marks in examination beyond their expectation. Any further improvement in the contents of the book by making corrections, omission and inclusion is keen to be achieved based on suggestions from the reader for which the author shall be obliged. I acknowledge special thanks to Mr. Rajeev Biyani, Chiarman & Dr. Sanjay Biyani, Director (Acad.) Biyani Group of Colleges, who are the backbone and main concept providers and also have been constant source of motivation throughout this endeavour. I look forward to receive valuable suggestions from professors of various educational institutions, other faculty members and the students for improvement of the quality of the book. The reader may feel free to send their comments and suggestions to the under mentioned address. Note : For detail study of Data Structure and Algorithm students can refer the book written by the same author as data structure and algorithm by Bhavana Sangamnerkar.

Author

Fore more detail:- http://www.gurukpo.com

Syllabus
B.C.A. Part-I

Data Structure and Algorithms


Algorithms, Pseudo Code, Efficiency of Algorithms, Analyzing Algorithms and Problems, Complexity Measures, Basic Time Analysis of an Algorithm, Space Complexity. Data Abstraction and Basic Data Structures, Data Types, Abstract Data Types and C++ Classes. String Processing (Storing Strings, String Operations, Word Processing, Pattern Matching Algorithms). Arrays and their Representation, Representation of Linear Arrays in Memory, Sorting and Searching, Bubble Sort and Binary Search, Multidimensional Arrays, Pointer Arrays, Records and Record Structures. Linked Lists, Representation of Linked List in Memory, Insertion, Deletion and Searching of Linked List, Two Way Lists, Stacks, Array Representation of Stacks, Arithmetic Expressions, Polish Notations, Quick Sort, Recursion, Queues, De-queues, Priority Queues. Tables and Searching, Linear Search, Binary Search, Hash Tables, Trees, Binary and Nary Trees, Representation of Binary Trees in Memory, Traversing Binary Trees, Traversal Algorithms using Stacks, Header Nodes, Threads, Binary Search Trees, Heap, Heapsort, Huffmans Algorithm. Graph and their Representation, Sequential Representation, Warshalls Algorithm, Linked Representation of Graphs, Operations on Graphs Traversing a Graph. Sorting and Searching : Sequential, Binary and Hashed Searching, Internal and External Sorting Techniques, Bubble Sort, Insertion Sort, Selection Sort, Merge Sort, Radix Sort and Quick Sort Comparison.

Fore more detail:- http://www.gurukpo.com

Content
S.No. 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. Name of Topic Basics of Algorithms Data Structure Organisation Arrays Strings C++ : Classes and Objects Linked List Stacks Queue Sorting and Searching Techniques Graph Tree Page No. 7-21 22-27 28-38 39-52 53-64 65-68 69-78 79-85 86-95 96-105 106-134

Fore more detail:- http://www.gurukpo.com

Chapter-1

Basics of Algorithms
Q.1. What are the various steps to plan Algorithm ?

Ans.: Following steps must be followed to plan any algorithm : (1) Device Algorithm : Creating an algorithm is an art in which may never be fully automated. When we get the problem, we should first analyse the given problem clearly and then write down some steps on the paper. Validate Algorithm : Once an algorithm is devised , it is necessary to show that it computes the correct answer for all possible legal inputs . This process is known as algorithm validation. The algorithm need not as yet be expressed as a program. It is sufficient to state it in any precise way. The purpose of validation is to assure us that this algorithm will work correctly independently of the issues concerning the programming language it will eventually be written in. Once the validity of the method has been shown, a program can be written and a second phase begins. This phase is referred to as program proving or program verification. Analyse Algorithm : As an algorithm is executed , it uses the computers central processing unit to perform operations and its memory ( both immediate and auxiliary) to hold the program and data. Analysis of algorithm or performance analysis refers to the task of determining how much computing time and storage an algorithm requires. An important result of this study is that it allows you to make quantitative judgments about the value of one algorithm over another. Another result is that it allows you to predict whether the software will meet any efficiency constraints that exist. Analysis can be made by taking into consideration. Test A Program : Testing a program consists of 2 phases : debugging and performance management. Debugging is the process of executing programs on sample data sets to determine whether results are incorrect if so corrects them. Performance management is the process of executing a correct program on data sets and measuring the time and space it takes to compute the results. These timing figures are useful in that they may confirm a previously done analysis and point out logical places to perform useful optimization.

(2)

(3)

(4)

Fore more detail:- http://www.gurukpo.com

Q.2.

Define Algorithms with suitable example. Chocolate Cream Pie : (1) Heat milk, marshmallows and chocolate in 3-quart saucepan over low heat, stirring constantly, until chocolate and marshmallows are melted and blended. Refrigerate about 20 minutes, stirring occasionally until mixture mounds slightly when dropped from a spoon. Beat whipping cream in chilled small bowl with electric mixer on high speed until soft peaks form. Fold chocolate mixture into whipped cream. Pour into pie shell. Refrigerate uncovered about 8 hours or until set. Garnish with milk chocolate curls and whipped cream. Place the oil pan underneath the oil plug of your car. Unscrew the oil plug. Drain oil. Replace the oil plug. Remove the oil cap from the engine. Pour in 4 quarts of oil. Replace the oil cap.

Ans.: Consider the following three examples. What do they all have in common?

(2)

How to change your motor oil (1) (2) (3) (4) (5) (6) (7)

Each of these examples is algorithm, a set of instructions for solving a problem. Once we have created an algorithm, we no longer need to think about the principles on which the algorithm is based. This means that algorithms are a way of capturing intelligence and sharing it with others. Once you have encoded the necessary intelligence to solve a problem in an algorithm, many people can use your algorithm without needing to become experts in a particular field. Algorithms are especially important to computers because computers are really general purpose machines for solving problems. But in order for a computer to be useful, we must give it a problem to solve and a technique for solving the problem. Through the use of algorithms, we can make computers "intelligent" by programming them with various algorithms to solve problems. Because of their speed and accuracy, computers are well-suited for solving tedious problems such as searching for a name in a large telephone directory or adding a long column of numbers. However, the usefulness of computers as problem solving machines is limited because the solutions to some problems cannot be stated in an algorithm. Much of the study of computer science is dedicated to discovering efficient algorithms and representing them so that they can be understood by computers.

Fore more detail:- http://www.gurukpo.com

During our study of algorithms, we will discuss what defines an algorithm, how to represent algorithms, and what makes algorithms efficient. Along the way we will illustrate these concepts by introducing several algorithms for sorting. By the end of our study, you should be able to do the following: Write some simple algorithms, Sort numbers using three basic sorting algorithms, and Compare the sorting algorithms for efficiency. In the introduction, we gave an informal definition of an algorithm as "a set of instructions for solving a problem" and we illustrated this definition with a recipe, and instructions for changing the oil in a car engine. You also created your own algorithm for putting letters and numbers in order. While these simple algorithms are fine for us, they are much too ambiguous for a computer. In order for an algorithm to be applicable to a computer, it must have certain characteristics. We will specify these characteristics in our formal definition of an algorithm. An algorithm is a well-ordered collection of unambiguous and effectively computable operations that when executed produces a result and halts in a finite amount of time [Schneider and Gersting 1995]. With this definition, we can identify five important characteristics of algorithms : (1) (2) (3) (4) (5) Algorithms are well-ordered. Algorithms have unambiguous operations. Algorithms have effectively computable operations. Algorithms produce a result. Algorithms halt in a finite amount of time.

When writing algorithms, we have several choices of how we will specify the operations in our algorithm. One option is to write the algorithm using plain English. Although plain English may seem like a good way to write an algorithm, it has some problems that make it a poor choice. First, plain English is too wordy. When we write in plain English, we must include many words that contribute to correct grammar or style but do nothing to help communicate the algorithm. Second, plain English is too ambiguous. Often an English sentence can be interpreted in many different ways. Remember that our definition of an algorithm requires that each operation be unambiguous. Another option for writing algorithms is using programming languages. These languages are collections of primitives (basic operations) that a computer understands. While programming languages avoid the problems of being wordy

Fore more detail:- http://www.gurukpo.com

and ambiguous, they have some other disadvantages that make them undesirable for writing algorithms. Consider the following lines of code from the programming language C++. a = 1; b = 0; while (a <= 10) { b = b + a; a++; } cout << b; This algorithm sums the numbers from 1 to 10 and displays the answer on the computer screen. However, without some special knowledge of the C++ programming language, it would be difficult for you to know what this algorithm does. Using a programming language to specify algorithms means learning special syntax and symbols that are not part of Standard English. For example, in the code above, it is not very obvious what the symbol "++" or the symbol "<<" does. When we write algorithms, we would rather not worry about the details of a particular programming language. What we would really like to do is combine the familiarity of plain English with the structure and order of programming languages. A good compromise is structured English. This approach uses English to write operations, but groups operations by indenting and numbering lines. An example of this approach is the directions for changing motor oil in the introduction lesson. Each operation in the algorithm is written on a separate line so they are easily distinguished from each other. We can easily see the advantage of this organization by comparing the structured English algorithm with the plain English algorithm. How to change your motor oil Plain English First, place the oil pan underneath the oil plug of your car. Next, unscrew the oil plug and drain the oil. Now, replace the oil plug. Once the old oil is drained, remove the oil cap from the engine and pour in 4 quarts of oil. Finally, replace the oil cap on the engine. Structured English 1. Place the oil pan underneath the oil plug of your car. Unscrew the oil plug. Drain oil. Replace the oil plug. Remove the oil cap from

2. 3. 4. 5.

Fore more detail:- http://www.gurukpo.com

the engine. 6. 7. Pour in 4 quarts of oil. Replace the oil cap.

For the remainder of this study, we will write our algorithms using the structured English approach. Q.3. How can we analyse an Algorithm?

Ans.: Analysis of Algorithms (AofA) is a field in computer science whose overall goal is an understanding of the complexity of algorithms. While an extremely large amount of research is devoted to worst-case evaluations, the focus in these pages is methods for average-case and probabilistic analysis. Properties of random strings, permutations, trees, and graphs are thus essential ingredients in the analysis of algorithms. To analyze an algorithm is to determine the amount of resources (such as time and storage) necessary to execute it. Most algorithms are designed to work with inputs of arbitrary length. Usually the efficiency or complexity of an algorithm is stated as a function relating the input length to the number of steps (time complexity) or storage locations (space complexity). Algorithm analysis is an important part of a broader computational complexity theory, which provides theoretical estimates for the resources needed by any algorithm which solves a given computational problem. These estimates provide an insight into reasonable directions of search of efficient algorithms. Q.4. Explain Analysis of Algorithm in terms of different Order Notations.

Ans.: In theoretical analysis of algorithms it is common to estimate their complexity in asymptotic sense, i.e., to estimate the complexity function for reasonably large length of input. Big O notation, omega notation and theta notation are used to this end. For instance, binary search is said to run an amount of steps proportional to a logarithm, or in O(log(n)), colloquially "in logarithmic time". Usually asymptotic estimates are used because different implementations of the same algorithm may differ in efficiency. However the efficiencies of any two "reasonable" implementations of a given algorithm are related by a constant multiplicative factor called hidden constant. Asymptotic Notation : If we want to treat large problems (these are the critical ones), we are interested in the asymptotic behavior of the growth of the running time function.

Fore more detail:- http://www.gurukpo.com

Thus, when comparing the running times of two algorithms : Constant factors can be ignored. Lower order terms are unimportant when the higher order terms are different. For instance, when we analyze selection sort, we find that it takes T(n) = n2 + 3n - 4 array accesses. For large values of n, the 3n - 4 part is insignificant compared to the n2 part. An algorithm that takes a time of 100n2 will still be faster than an algorithm that n3 for any value of n larger than 100. Asymptotically Tight Upper and Lower Bound : Big-Theta ""-Notation : Definition : Let f(n) and g(n) be real-valued functions of a single nonnegative integer argument. We write f(n) = (g(n)) if there exist positive real-valued constants c1, c2 and a positive integer n0 such that :
0 c1 g(n) f(n) c2 g(n) for all n n0 .

In other words : For large inputs (asymptotically) f(n) is "sandwiched" between c1 g(n) and c2 g(n). Examples : 2n2+3n is &#x03B8(n2). 2n3+3n is not &#x03B8(n2). Asymptotically Tight Upper Bound : Big-Oh "O"-Notation : Definition : Let f(n) and g(n) be real-valued functions of a single nonnegative integer argument. We write f(n) = O(g(n)) if there exist a positive real-valued constant c and a positive integer n0 such that :
0 f(n) c g(n) for all n n0 .

In other words, for large inputs (asymptotically) f(n) is below c g(n) :

Fore more detail:- http://www.gurukpo.com

The ""-Notation is stronger than the O-notation. Examples : 3n-6 is O(n). 9n4+12n2+1234 is O(n4). n+log(n) is O(n). log(n)+5log(log(n)) is O(log(n)). 1234554321 is O(1). 3/n is O(1/n). Asymptotically Tight Lower Bound : Big-Omega ""-Notation : Definition : Let f(n) and g(n) be real-valued functions of a single nonnegative integer argument. We write f(n) = (g(n)) if there exist a positive real-valued constant c and a positive integer n0 such that :
0 c g(n) f(n) for all n n0 .

In other words : For large inputs (asymptotically) f(n) is above c g(n) . Note : We have f(n) = (g(n)) iff (if and only if)
f(n) = O(g(n)) and f(n) = (g(n)).

In other words : If f(n) is &# x0398(g(n)), the f(n) is &# x03A9(g(n)). If f(n) is &# x0398(g(n)), then f(n) is O(g(n)).

Fore more detail:- http://www.gurukpo.com

Example : 2n3+3n is &#x03A9(n3). Asymptotically Non-Tight Upper Bound : Little-oh "o"-Notation : Definition : Let f(n) and g(n) be real-valued functions of a single nonnegative integer argument. We write f(n) = o(g(n)) if for any positive realvalued constant c exists a positive integer n0 such that :
0 f(n) c g(n) for all n n0 .

In other words, the inequality holds for all constants c. For any constant c we can come up with large enough inputs n so that f(n) is below c g(n).
g(n) grows a lot faster than f(n) : f(n)/g(n)0 as n.

Example : log(n) is o(n) Asymptotically Non-Tight Lower Bound: Little-Omega "" Notation Definition : Let f(n) and g(n) be real-valued functions of a single nonnegative integer argument. We write f(n) = (g(n)) if for any positive realvalued constant c exists a positive integer n0 such that :
0 c g(n) f(n) for all n n0 .

As an alternative definition we can say the following : Definition : Let f(n) and g(n) be real valued functions of an integer variable. We say f(n) is (g(n)) if g(n) is o(f(n)). This is pronounced as "f(n) is little-omega of g(n)".
f(n) grows a lot faster than f(n) : f(n)/g(n) as n.

Example : n2 is (nlog(n)). Q.5. Define Efficiency of an Algorithm in terms of Time and Space.

Ans.: Efficiency of an algorithm : In computer science, efficiency is used to describe properties of an algorithm relating to how much of various types of resources it consumes. The two most frequently encountered are speed or running time, the time it takes for an algorithm to complete, and space, the memory or non-volatile storage used by the algorithm during its operation. Optimization is the process

Fore more detail:- http://www.gurukpo.com

of making code as efficient as possible, sometimes focusing on space at the cost of speed, or vice versa. The speed of an algorithm is measured in various ways. The most common method uses time complexity to determine the Big-O of an algorithm: often, it is possible to make an algorithm faster at the expense of space. This is the case whenever you cache the result of an expensive calculation rather than recalculating it on demand. This is a very common method of improving speed, so much so that languages often add special features to support it, such as C++'s mutable keyword. The space of an algorithm is actually two separate but related things. The first part is the space taken up by the compiled executable on disk (or equivalent, depending on the hardware and language) by the algorithm. This can often be reduced by preferring run-time decision making mechanisms (such as virtual functions and run-time type information) over certain compile-time decision making mechanisms (such as macro substitution and templates). This, however, comes at the cost of speed. The other part of algorithm space measurement is the amount of temporary memory taken up during processing. For example, pre-caching results, as mentioned earlier, improves speed at the cost of this attribute. Optimization of algorithms frequently depends on the properties of the machine the algorithm will be executed on. For example, one might optimize code for time efficiency in applications for home computers with sizable amounts of memory, while code to be placed in small, memory-tight devices may have to be made to run slower to conserve space. One simple way to determine whether an optimization is worthwhile is as follows: Let the original time and space requirements (generally in Big-O notation) of the algorithm be O1 and O2. Let the new code require N1 and N2 time and space respectively. If N1N2 < O1O2, the optimization should be carried out. However, as mentioned above, this may not always be true. One must be careful, in the pursuit of good coding style, not to over-emphasize efficiency. Nearly all of the time, a clean and usable design is much more important than a fast, small design. There are exceptions to this rule (such as embedded systems, where space is tight, and processing power minimal) but these are rarer than one might expect. Computational complexity theory, as a branch of the theory of computation in computer science, investigates the problems related to the amounts of resources required for the execution of algorithms (e.g., execution time), and the inherent difficulty in providing efficient algorithms for specific computational problems. A typical question of the theory is, "As the size of the input to an algorithm increases, how do the running time and memory requirements of the algorithm

Fore more detail:- http://www.gurukpo.com

change and what are the implications and ramifications of that change?" In other words, the theory, among other things, investigates the scalability of computational problems and algorithms. In particular, the theory places practical limits on what computers can accomplish. Exact (not asymptotic) measures of efficiency can sometimes be computed but they usually require certain assumptions concerning the particular implementation of the algorithm, called model of computation. A model of computation may be defined in terms of an abstract computer, e.g., Turing machine, and/or by postulating that certain operations are executed in unit time. For example, if the sorted set to which we apply binary search has N elements, and we can guarantee that a single binary lookup can be done in unit time, then at most log2 N + 1 time units are needed to return an answer. Exact measures of efficiency are useful to the people who actually implement and use algorithms, because they are more precise and thus enable them to know how much time they can expect to spend in execution. To some people (e.g. game programmers), a hidden constant can make all the difference between success and failure. Time efficiency estimates depend on what we define to be a step. For the analysis to make sense, the time required to perform a step must be guaranteed to be bounded above by a constant. One must be careful here; for instance, some analyses count an addition of two numbers as a step. This assumption may not be warranted in certain contexts. For example, if the numbers involved in a computation may be arbitrarily large, addition no longer can be assumed to require constant time Q.6. Compare the Performance of an Algorithm. Explain Algorithmic Complexity Measures.

Ans.: Our aim is to compare the performance of algorithms. We can consider the average case or the worst case performance (referring to an instance of a given problem). Usually we treat only the worst case performance : The worst case occurs fairly often, example: looking for in entry in a database that is not present. The result of the worst case analysis is often not different to the average case analysis (same order of complexity). Running Times : One way to compare running times is simply to run several tests for each algorithm and compare the timings.

Fore more detail:- http://www.gurukpo.com

Another way is to estimate the time required for an algorithm to solve a problem. The result of the analysis of an algorithm is usually a formula giving the amount of machine operations (e.g., floating point operations, number of memory accesses, number of comparisons, etc ) or some other metric (e.g., number of elements to sort, neurons or connections in a neural network, vertices or edges in a tree, etc. ), that the algorithm takes to complete. In the following we write running times as a function of n. Space Complexity : Running time is usually the thing we care most about. But it can be as well important to analyze the amount of memory used by a program. If a program takes a lot of time, you can still run it, and just wait longer for the result. However if a program takes a lot of memory, you may not be able to run it at all, so this is an important parameter to understand. We analyze things differently for recursive and iterative programs. For an iterative program, it is usually just a matter of looking at the variable declarations and storage allocation calls, e.g., array of n numbers. Analysis of recursive program space is more complicated: the space used at any time is the total space used by all recursive calls active at that time. Each recursive call takes a constant amount of space: some space for local variables and function arguments, and also some space for remembering where each call should return to. Q.7. What is Pseudo Code? Explain how can we use Pseudo Code to design a Program?

Ans.: Pseudo code is a short hand way of describing a computer program. Rather than use the specific syntax of a computer language, more general wording is used. Using pseudocode, it is easier for a non-programmer to understand the general workings of the program. Pseudo code (pronounced SOO-doh-kohd) is a detailed yet readable description of what a computer program or algorithm must do, expressed in a formallystyled natural language rather than in a programming language. Pseudocode is sometimes used as a detailed step in the process of developing a program. It allows designers or lead programmers to express the design in great detail and provides programmers a detailed template for the next step of writing code in a specific programming language.

Fore more detail:- http://www.gurukpo.com

Because pseudocode is detailed yet readable, it can be inspected by the team of designers and programmers as a way to ensure that actual programming is likely to match design specifications. Catching errors at the pseudocode stage is less costly than catching them later in the development process. Once the pseudocode is accepted, it is rewritten using the vocabulary and syntax of a programming language. Pseudocode is sometimes used in conjunction with computer-aided software engineering-based methodologies. It is possible to write programs that will convert a given pseudocode language into a given programming language. Pseudocode Example : 1. if credit card number is valid then execute transaction based on number and order else show a generic failure message end if 2. A bank will grant loan under the following conditions : (i) (ii) If a customer has an account with the bank and had no loan outstanding, loan will be granted. If a customer has an account with the bank but some amount is outstanding from previous loans then loan will be granted if special approval is needed.

(iii) Reject all loan applications in all other cases. IF customer has a Bank Account THEN IF Customer has no dues from previous account THEN Allow loan facility ELSE IF Management Approval is obtained THEN Allow loan facility ELSE Reject ENDIF ENDIF ELSE Reject ENDIF

Fore more detail:- http://www.gurukpo.com

Chapter-2

Data Structure Ogranisation


Q.1. Explain Data Types along with their sizes and ranges.

Ans.: Data Types : The type of a data object in C determines the range and kind of values an object can represent, the size of machine storage reserved for an object, and the operations allowed on an object. Functions also have types, and the function's return type and parameter types can be specified in the function's declaration Data Sizes : An object of a given data type is stored in a section of memory having a discreet size. Objects of different data types require different amounts of memory. Following table shows the size and range of the basic data types. Sizes and Ranges of Data Types :

Type Integral Types :


short int , or signed short int unsigned short int int or signed int unsigned int long int , or signed long int

Size

Range

16 bits 16 bits 32 bits 32 bits 32 bits 64 bits 32 bits 64 bits 64 bits

-32768 to 32767 0 to 65535 -2147483648 to 2147483647 0 to 4294967295 - 2147483648 to 2147483647 - 9223372036854775808 to 9223372036854775807 0 to 4294967295 0 to 18446744073709551615 -9223372036854775808 to 9223372036854775807

(OpenVMS)
long int , or signed long int (Digital

UNIX)
unsigned long int (OpenVMS) unsigned long int (Digital UNIX) signed __int64 (Alpha)

Fore more detail:- http://www.gurukpo.com

unsigned __int64 (Alpha)

64 bits

0 to 18446744073709551615

Type Integral Character Types :


char and signed char unsigned char wchar_t

Size

Range

8 bits 8 bits 32 bits

-128 to 127 0 to 255 0 to 4294967295

Floating- Point Types (range is for absolute value) :


float double long double (OpenVMS Alpha) long double (OpenVMS VAX, Digital

32 bits 64 bits 128 bits Same as


double

1.1 x 10 -38 to 3.4 x 10 38 2.2 x 10 -308 to 1.7 x 10 308 3.4 x 10 -49321 to 1.2 x 10 49321 Same as double

UNIX)

Derived types can require more memory space. Q.2. What is Data Abstraction? Define Abstract Data Types. Ans.: Abstraction : In computer science, abstraction is a mechanism and practice to reduce and factor out details so that one can focus on a few concepts at a time.The major purpose of a database system is to provide users with an abstract view of the system. The system hides certain details of how data is stored and created and maintained Complexity should be hidden from users. Data Abstraction : Data abstraction is the enforcement of a clear separation between the abstract properties of a data type and the concrete details of its implementation. The abstract properties are those that are visible to client code that makes use of the data type--the interface to the data type--while the concrete implementation is kept entirely private, and indeed can change, for example to incorporate efficiency improvements over time. The idea is that such changes are not supposed to have any impact on client code, since they involve no difference in the abstract behaviour. For example, one could define an abstract data type called lookup table, where keys are uniquely associated with values, and values may be retrieved by specifying their corresponding keys. Such a lookup table may be implemented in various ways: as a hash table, a binary search tree, or even a simple linear list. As

Fore more detail:- http://www.gurukpo.com

far as client code is concerned, the abstract properties of the type are the same in each case. Of course, this all relies on getting the details of the interface right in the first place, since any changes there can have major impacts on client code. Another way to look at this is that the interface forms a contract on agreed behaviour between the data type and client code; anything not spelled out in the contract is subject to change without notice. Languages that implement data abstraction include Ada and Modula-2. Objectoriented languages are commonly claimed to offer data abstraction; however, their inheritance concept tends to put information in the interface that more properly belongs in the implementation; thus, changes to such information ends up impacting client code, leading directly to the Fragile binary interface problem. Abstract Data Types : The Concept of Abstraction : Abstraction allows one to collect instances of entities into groups in which their common attributes need not be considered. Two kinds of abstractions in programming languages are process abstraction and data abstraction. The concept of process abstraction is one of the oldest.? All subprograms are process abstractions because they provide a way for a program to specify that some process is to be done, without providing the details of how it is to be done. Process abstraction is crucial to the programming process.? The ability to abstract away many of the details of algorithms in subprograms makes it possible to construct, read, and understand large programs. All subprograms, including concurrent exception handlers, are process abstractions. subprograms, and

Encapsulation : Encapsulation is a grouping of subprograms and the data that they manipulate. An encapsulation provides an abstracted system and a logical organization for a collection of related computations. They are often placed in libraries and made available for reuse in programs other than those for which they are written.

Fore more detail:- http://www.gurukpo.com

Introduction to Data Abstraction : An abstract data type is simply an encapsulation that includes only the data representation of one specific data type and the subprograms that provide the operations for that type. An instance of an abstract data type is called an object. Object-oriented programming is an outgrowth of the use of data abstraction. All built-in types are abstract data types, even those of FORTRAN I Floating-point types employ a key concept in data abstraction: information hiding? The actual format of the data in a floatingpoint cell is hidden from the user. The concept of user-defined abstract data types is relatively recent. They should provide : o A type definition that allows program units to declare variables of the type but hides the representation of these variables. A set of operations for manipulating objects of the type.

Floating-Point as an Abstract Data Type :

User Defined Abstract Data Types :

An abstract data type is a data type that satisfies two conditions : o o The representation, or definition, of the type and the operations are contained in a single syntactic unit. The representation of objects of the type is hidden from the program units that use the type, so only direct operations possible on those objects are those provided in the type? Definition.

Program units that use a specific abstract data type are called clients of that type. A benefit of information hiding is increased reliability.? This is because clients cannot change the underlying representations of objects directly, either intentionally or by accident, thus increasing the integrity of the object

Design Issues :

Fore more detail:- http://www.gurukpo.com

A facility for defining abstract data types in a language must provide a syntactic unit that can encapsulate the type definition and subprogram definitions of the abstraction operations. Concurrent Pascal, Smalltalk, C++, and Java directly support abstract data types. Some design issues beyond encapsulation are whether the kinds of types that can be abstract should be restricted, whether abstract data types can be parameterized, and what access controls are provided, and how such controls are specified. C++ o Unlike, Ada and Modula-2, which provide encapsulation that can used to simulate abstract data types, C++ provides the class, which more directly support abstract data types. The data defined in a class are called data members; the functions defined in a class are called member functions. Classes may contain both hidden and visible entities.

Language Examples :

o o

Fore more detail:- http://www.gurukpo.com

Chapter-3

Arrays
Q.1. What are the characteristics of Arrays in C?
An array holds elements that have the same data type. Array elements are stored in subsequent memory locations. Two-dimensional array elements are stored row by row in subsequent memory locations. Array name represents the address of the starting element. Array size should be mentioned in the declaration. Array size must be a constant expression and not a variable. 2) 3) 4) 5)

Ans.: 1)

Q.2. Ans.:

How do I know how many elements an Array can hold?

The amount of memory an array can consume depends on the data type of an array. In DOS environment, the amount of memory an array can consume depends on the current memory model (i.e. Tiny, Small, Large, Huge, etc.). In general an array cannot consume more than 64 kb. Consider following program, which shows the maximum number of elements an array of type int, float and char can have in case of Small memory model. main( )

{
int i[32767] ; float f[16383] ; char s[65535] ;

} Q.3. How can we declare an Array?

Ans.: Declaring Arrays : Arrays are declared with the bracket punctuators [ ], as shown in the following syntax :
storage-class-specifier(opt) type-specifier declarator [constant-expression-list(opt)];

The following example shows a declaration of a 10-element array of integers, a variable called table_one : int table_one[10];

Fore more detail:- http://www.gurukpo.com

The type-specifier shows the data type of the elements. The elements of an array can be of any scalar or aggregate data type. The identifier table_one specifies the name of the array. The constant expression 10 gives the number of elements in a single dimension. Arrays in C are zero-based; that is, the first element of the array is identified with a 0 subscript, such as the one shown in the following example : int x[5]; x[0] = 25; /* The first array element is assigned the value 25 */ The expression between the brackets in the declaration must be an integral constant expression with a value greater than zero. Omitting the constant expression creates an incomplete array declaration, which is useful in the following cases :

If the array is declared external and its storage is allocated by a definition in another place, you can omit the constant expression for convenience when the array name is declared, as in the following example : extern int array1[]; int first_function(void) { . . . } In a separate compilation unit : int array1[10]; int second_function(void) { . . . } The array size specifier may only be omitted from the first pair of brackets in a multidimensional array declaration. This is because an array's elements must have complete types, even if the array itself has an incomplete type.

Fore more detail:- http://www.gurukpo.com

If the declaration of the array includes initializers, you can omit the size of the array, as in the following example : char array_one[] = "Shemps"; char array_two[] = { 'S', 'h', 'e', 'm', 'p', 's', '\0' }; The two definitions initialize variables with identical elements. These arrays have seven elements: six characters and the null character (\0), which terminates all character strings. The size of the array is determined from the number of characters in the initializing character-string constant or initialization list. Initializing an incomplete array completes the array type. An array is completed at the end of its initializer list.

If you use the array as a function parameter, the array must be defined in the calling function. However, the declaration of the parameter in the called function can omit the constant expression within the brackets. The address of the first element of the array is passed. Subscripted references in the called function can modify elements of the array. The following example shows how to use an array in this manner : main() { /* Initialize array static char arg_str[] = "Thomas"; int sum; sum = adder(arg_str); /* Pass address of first array element */ . . . } /* adder adds ASCII values of letters in array int adder( char param_string[]) { int i, sum = 0; /* Incrementer and sum */ */ /* Loop until NULL char for (i = 0; param_string[i] != '\0'; i++) sum += param_string[i]; */ */

Fore more detail:- http://www.gurukpo.com

return sum; } After the function adder is called, parameter param_string receives the address of the first character of argument arg_str, which can then be accessed in adder . The declaration of param_ string serves only to give the type of the parameter, not to reserve storage for it. Array members can also be pointers. The following example declares an array of floating-point numbers and an array of pointers to floating-point numbers : float fa[11], *afp[17]; When a function parameter is declared as an array, the compiler treats the declaration as a pointer to the first element of the array. For example, if x is a parameter and is intended to represent an array of integers, it can be declared as any one of the following declarations : int x[]; int *x; int x[10]; Note that the specified size of the array does not matter in the case of a function parameter, since the pointer always points to only the first element of the array. C supports arrays declared as an array of arrays. These are sometimes called multidimensional arrays. Consider the following example, where variable table_one is a two-dimensional array containing 20 integers : int table_one[10][2]; Arrays are stored in row-major order, which means the element table_one[0][0] (in the previous example) immediately precedes table_one[0][1], which in turn immediately precedes table_one[1][0] . Q.4. What are the steps to initialize an Array?

Ans.: Initializing Arrays : Arrays are initialized with a brace-enclosed list of constant expressions. A list of initializers for an incomplete array declaration completes the array's type and completely defines the array size. Therefore, when initializing an array of unknown size, the number of initializers in the initializer list determines the size of the array. For example, the following declaration initializes an array of three elements : int x[ ] = { 1, 2, 3 };

Fore more detail:- http://www.gurukpo.com

If the array being initialized has a storage class of static , the initializers must be constant expressions. Initializers for an array of a given size are assigned to array members on a oneto-one basis. If there are too few initializers for all members, the remaining members are initialized to 0. Listing too many initializers for a given size array is an error. For example : int x[5] = { 0, 1, 2, 3, 4, 5 }; /* error */

String literals are often assigned to a char or wchar_t array. In this case, each character of the string represents one member of a one-dimensional array, and the array is terminated with the null character. When an array is initialized by a pointer to a string literal, the string literal cannot be modified through the pointer. When initializing an array with a string literal, use quotation marks around the initializing string. For example : char string[26] = { "This is a string literal." }; /* The braces above are optional here */ The terminating null character is appended to the end of the string if the size permits, as it does in this case. Another form for initializing an array with characters is the following : char string[12] = {'T', 'h', 'i', 's', ' ', 'w', 'a', 'y' }; The preceding example creates a one-dimensional array containing the string value "This way ". The characters in this array can be freely modified. Remaining uninitialized array members will be automatically initialized to zero. If the size of the array used for a string literal is not explicitly stated, its size is determined by the number of characters in the string (including the terminating null character). If the size of the array is explicitly stated, initializing the array with a string literal longer than the array is an error. Note : There is one special case where the null character is not automatically appended to the array. This case is when the array size is explicitly specified and the number of initializers completely fills the array size. For example : char c[4] = "abcd"; Here, the array c holds only the four specified characters, a , b , c , and d . No null character terminates the array. Using the following rules, you can omit braces when initializing the members of a multidimensional arrays:

Fore more detail:- http://www.gurukpo.com

When initializing arrays, you can omit the outermost pair of braces. If the initializer list includes all of the initializers for the object being initialized, you can omit the inner braces.

Consider the following example : float x[4][2] = { { 1, 2 } { 3, 4 } { 5, 6 } }; In this example, 1 and 2 initialize the first row of the array x , and the following two lines initialize the second and third rows, respectively. The initialization ends before the fourth row is initialized, so the members of the fourth row default to 0. Here is the result : x[0][0] = 1; x[0][1] = 2; x[1][0] = 3; x[1][1] = 4; x[2][0] = 5; x[2][1] = 6; x[3][0] = 0; x[3][1] = 0; The following declaration achieves the same result : float x[4][2] = { 1, 2, 3, 4, 5, 6 }; Here, the compiler fills the array row by row with the available initial values. The compiler places 1 and 2 in the first row (x[0] ), 3 and 4 in the second row (x[1] ), and 5 and 6 in the third row (x[2] ). The remaining members of the array are initialized to zero. Q.5. Compare and relate Pointers with Arrays.

Ans.: Pointers and Arrays : Data objects in an array can be referenced through pointers instead of using array subscripts. The data type of such a pointer is referred to as "pointer to array of type". The array name itself behaves like a pointer, so there are several alternative methods to accessing array elements. For example :

Fore more detail:- http://www.gurukpo.com

int x[5] = { 0, 1, 2, 3, 4 }; int *p = x; int a, b; a = *(x + 3); b = x[3];

/* Array x declared with five elements */ /* Pointer declared and initialized to point */ /* to the first element of the array x */ /* Pointer x incremented by twelve bytes */ /* to reference element 3 of x */ /* b now holds the same value as a */

In the previous example, a receives the value 3 by using the dereferencing operator (*). b receives the same value by using the subscripting operator For more information on the different unary operators. Note that the assignment of a was a result of incrementing the pointer to x . This principle, known as scaling, applies to all types of pointer arithmetic. In scaling, the compiler considers the size of an array element when calculating memory addresses of array members. For example, each member of the array x is 4 bytes long, and adding three to the initial pointer value automatically converts that addition to 3 * (the size of the array member, which in this case is 4). Therefore, the intuitive meaning of z = *(y + 3); is preserved. When passing arrays as function arguments, only a pointer to the first element of the array is passed to the called function. The conversion from array type to pointer type is implicit. Once the array name is converted to a pointer to the first element of the array, you can increment, decrement, or dereference the pointer, just like any other pointer, to manipulate data in the array. For example : int func(int *x, int *y) { *y = *(x + 4); } Remember that a pointer is large enough to hold only an address; a pointer into an array holds the address of an element of that array. The array itself is large enough to hold all members of the array. When applied to arrays, the size of operator returns the size of the entire array, not just the size of the first element in the array. Q.6. How will you explain Record and Record Structure? Record and record structures : The ::struct::record package provides a mechanism to group variables together as one data structure, similar to a 'C' /* Various elements of the arrays are accessed */ /* The arrays are converted to pointers */

Fore more detail:- http://www.gurukpo.com

structure. The members of a record can be variables or other records. However, a record can not contain circular record, i.e. records that contain the same record as a member. This package was structured so that it is very similar to how Tk objects work. Each record definition creates a record object that encompasses that definition. Subsequently, that record object can create instances of that record. These instances can then be manipulated with the cget and configure methods. The package only contains one top level command, but several sub commands (see below). It also obeys the namespace in which the record was define, hence the objects returned are fully qualified. record define instanceName2 ... ? recordName recordMembers ? instanceName1

Defines a record. recordName is the name of the record, and is also used as an object command. This object command is used to create instances of the record definition. recordMembers are the members of the record that make up the record definition. These are variables and other record. If optional instanceName args are given, then an instance is generated after the definition is created for each instanceName. record show record Returns a list of records that have been defined. record show instances recordName Returns the instances that have been instantiated by recordName. record show members recordName Returns the members that are defined for record recordName. It returns the same format as how the records were defined. record show values instanceName Returns a list of values that are set for the instance instanceName. The output is a list of key/value pairs. If there are nested records, then the values of the nested records will itself be a list. record exists record recordName Tests for the existence of a record with the name recordName. record exists instance instanceName Tests for the existence of a instance with the name instanceName. record delete record recordName Deletes recordName, and all instances of recordName. It will return an error if the record does not exist.

Fore more detail:- http://www.gurukpo.com

record delete instance instanceName Deletes instance with the name of instanceName. It will return an error if the instance does not exist. Record Members : Record members can either be variables, or other records, However, the same record can not be nested witin itself (circular). To define a nested record, you need to specify the record keyword, along the with name of the record, and the name of the instance of that nested record. For example, it would look like this : # this is the nested record record define mynestedrecord { nest1 nest2 } # This is the main record record define myrecord { mem1 mem2 {record mynestedrecord mem3} }

Fore more detail:- http://www.gurukpo.com

Chapter-4

Strings
Q.1. What is the difference between a String and an Array?
convention to determine its length. There are two kinds of programming languages: those in which a string is just an array of characters, and those in which its a special type. In C, a string is just an array of characters (type char), with one wrinkle: a C string always ends with a NULL character. The value of an array is the same as the address of (or a pointer to) the first element; so, frequently, a C string and a pointer to char are used to mean the same thing. An array can be of any length. If its passed to a function, theres no way the function can tell how long the array is supposed to be, unless some convention is used. The convention for strings is NULL termination; the last character is an ASCII NUL () character.

Ans.: An array is an array of anything. A string is a specific kind of an array with a well-known

Q.2.

What is the difference between Strings and Character Arrays?


will not, unless it is explicitly specified by using the static keyword. Actually, a string is a character array with following properties :

Ans.: A major difference is: string will have static storage duration, whereas as a character array

The multi-byte character sequence, to which we generally call string, is used to initialize an array of static storage duration. The size of this array is just sufficient to contain these characters plus the terminating NUL character. It not specified what happens if this array, i.e., string, is modified.

So the value of a string is the sequence of the values of the contained characters, in order.

Q.3.

What is the difference between "calloc(...)" and "malloc(...)"? calloc(...) allocates a block of memory for an array of elements of a certain size. By default the block is initialized to 0. The total number of memory allocated will be (number_of_elements * size). malloc(...) takes in only a single argument which is the memory required in bytes. malloc(...) allocated bytes of memory and not blocks of memory like calloc(...).

Ans.: (1)

Fore more detail:- http://www.gurukpo.com

(2)

malloc(...) allocates memory blocks and returns a void pointer to the allocated space, or NULL if there is insufficient memory available. calloc(...) allocates an array in memory with elements initialized to 0 and returns a pointer to the allocated space. calloc(...) calls malloc(...) in order to use the C++ _set_new_mode function to set the new handler mode.

Q.4.

What is the purpose of realloc( )?


of memory for which the size is to be altered. The second argument n specifies the new size. The size may be increased or decreased. If n is greater than the old size and if sufficient space is not available subsequent to the old region, the function realloc( ) may create a new region and all the old data are moved to the new region.

Ans.: The function realloc(ptr,n) uses two arguments.the first argument ptr is a pointer to a block

Q.5

What is difference between malloc()/free() and new/delete?


initiallize the object. new allocates memory and also invokes constructor to initialize the object. malloc() and free() do not support object semantics Does not construct and destruct objects string * ptr = (string *)(malloc (sizeof(string))) Are not safe Does not calculate the size of the objects that it construct Returns a pointer to void int *p = (int *) (malloc(sizeof(int))); int *p = new int; Are not extensible new and delete can be overloaded in a class "delete" first calls the object's termination routine (i.e. its destructor) and then releases the space the object occupied on the heap memory. If an array of objects was created using new, then delete must be told that it is dealing with an array by preceding the name with an empty []:Int_t *my_ints = new Int_t[10]; ... delete []my_ints;

Ans.: malloc allocates memory for object in heap but doesn't invoke object's constructor to

Fore more detail:- http://www.gurukpo.com

Q.6.

What is the difference between "new" and "operator new" ?

Ans.: "operator new" works like malloc. Q.7. What is the difference between realloc() and free()?
Undefined results occur if the Pointer parameter is not a valid pointer. If the Pointer parameter is a null value, no action will occur. The realloc subroutine changes the size of the block of memory pointed to by the Pointer parameter to the number of bytes specified by the Size parameter and returns a new pointer to the block. The pointer specified by the Pointer parameter must have been created with the malloc, calloc, or realloc subroutines and not been deallocated with the free or realloc subroutines. Undefined results occur if the Pointer parameter is not a valid pointer.

Ans.: The free subroutine frees a block of memory previously allocated by the malloc subroutine.

Q.8.

Is it better to use malloc() or calloc()?


operates slightly different from the other. malloc() takes a size and returns a pointer to a chunk of memory at least that big: void *malloc( size_t size ); calloc() takes a number of elements, and the size of each, and returns a pointer to a chunk of memory at least big enough to hold them all: void *calloc( size_t numElements, size_t sizeOfElement ); Theres one major difference and one minor difference between the two functions. The major difference is that malloc() doesnt initialize the allocated memory. The first time malloc() gives you a particular chunk of memory, the memory might be full of zeros. If memory has been allocated, freed, and reallocated, it probably has whatever junk was left in it. That means, unfortunately, that a program might run in simple cases (when memory is never reallocated) but break when used harder (and when memory is reused). calloc() fills the allocated memory with all zero bits. That means that anything there youre going to use as a char or an int of any length, signed or unsigned, is guaranteed to be zero. Anything youre going to use as a pointer is set to all zero bits. Thats usually a null pointer, but its not guaranteed.Anything youre going to use as a float or double is set to all zero bits; thats a floating-point zero on some types of machines, but not on all. The minor difference between the two is that calloc() returns an array of objects; malloc() returns one object. Some people use calloc() to make clear that they want an array.

Ans.: Both the malloc() and the calloc() functions are used to allocate dynamic memory. Each

Q.9.

You have two pairs : new() and delete() and another pair : alloc() and free().
Explain differences between eg. new() and malloc()
new and delete are preprocessors while malloc() and free() are functions. [we dont use brackets will calling new or delete].

Ans.1: 1.)

Fore more detail:- http://www.gurukpo.com

2.) 3.)

No need of allocate the memory while using new but in malloc() we have to use sizeof(). new will initlize the new memory to 0 but malloc() gives random value in the new alloted memory location [better to use calloc()] space for the object instace

Ans.2: new()

allocates continous malloc() allocates distributed space.

new() is castless, meaning that allocates memory for this specific type, malloc(), calloc() allocate space for void * that is cated to the specific class type pointer.

Q.10. String Processing --- Write out a function that prints out all the permutations of a String. For example, abc would give you abc, acb, bac, bca, cab, cba. Ans.: void PrintPermu (char *sBegin, char* sRest) { int iLoop; char cTmp; char cFLetter[1]; char *sNewBegin; char *sCur; int iLen; static int iCount; iLen = strlen(sRest); if (iLen == 2) { iCount++; printf("%d: %s%s\n",iCount,sBegin,sRest); iCount++; printf("%d: %s%c%c\n",iCount,sBegin,sRest[1],sRest[0]); return; } else if (iLen == 1) { iCount++; printf("%d: %s%s\n", iCount, sBegin, sRest); return; } else { // swap the first character of sRest with each of // the remaining chars recursively call debug print

Fore more detail:- http://www.gurukpo.com

sCur = (char*)malloc(iLen); sNewBegin = (char*)malloc(iLen); for (iLoop = 0; iLoop < iLen; iLoop ++) { strcpy(sCur, sRest); strcpy(sNewBegin, sBegin); cTmp = sCur[iLoop]; sCur[iLoop] = sCur[0]; sCur[0] = cTmp; sprintf(cFLetter, "%c", sCur[0]); strcat(sNewBegin, cFLetter); debugprint(sNewBegin, sCur+1); } } } void main() { char s[255]; char sIn[255]; printf("\nEnter a string:"); scanf("%s%*c",sIn); memset(s,0,255); PrintPermu(s, sIn); } Q.11. What is the difference between a string copy (strcpy) and a memory copy (memcpy)? When should each be used? Ans.: The strcpy() function is designed to work exclusively with strings. It copies each byte of the
source string to the destination string and stops when the terminating null character () has been moved. On the other hand, the memcpy() function is designed to work with any type of data. Because not all data ends with a null character, you must provide the memcpy() function with the number of bytes you want to copy from the source to the destination.

Q.12. How can I convert a String to a Number? Ans. : The standard C library provides several functions for converting strings to numbers of all
formats (integers, longs, floats, and so on) and vice versa.

Fore more detail:- http://www.gurukpo.com

The following functions can be used to convert strings to numbers : Function Name atof() atoi() atol() strtod() strtol() strtoul() Purpose Converts a string to a double-precision floating-point value. Converts a string to an integer. Converts a string to a long integer. Converts a string to a double-precision floating-point value and reports any leftover numbers that could not be converted. Converts a string to a long integer and reports any leftover numbers that could not be converted. Converts a string to an unsigned long integer and reports any leftover numbers that could not be converted.

Q13. How can I convert a Number to a String? Ans.: The standard C library provides several functions for converting numbers of all formats
(integers, longs, floats, and so on) to strings and vice versa The following functions can be used to convert integers to strings : Function Name itoa() ltoa() ultoa() Purpose Converts an integer value to a string. Converts a long integer value to a string. Converts an unsigned long integer value to a string.

The following functions can be used to convert floating-point values to strings : Function Name ecvt() fcvt() gcvt() Purpose Converts a double-precision floating-point value to a string without an embedded decimal point. Same as ecvt(), but forces the precision to a specified number of digits. Converts a double-precision floating-point value to a string with an embedded decimal point.

Q.14. Write a Program to interchange two variables without using the third one.
Ans.: a=7; b=2; a = a + b; b = a - b; a = a - b;

Q.15. How will you define String Processing along with the different String Operations?

Fore more detail:- http://www.gurukpo.com

Ans.: String Processing (Storing Strings and String Operations) : In C, a string is stored as a null-terminated char array. This means that after the last truly usable char there is a null, hex 00, which is represented in C by '\0'. The subscripts used for the array start with zero (0). The following line declares a char array called str. C provides fifteen consecutive bytes of memory. Only the first fourteen bytes are usable for character storage, because one must be used for the stringterminating null. char str[15]; The following is a representation of what would be in RAM, if the string "Hello, world!" is stored in this array. Characters: H e l l o , w o r l d ! Hex values: 48 65 6C 6C 6F 2C 20 77 6F 71 6C 64 21 00 Subscripts: 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 The name of the array is treated as a pointer to the array. The subscript serves as the offset into the array, i.e., the number of bytes from the starting memory location of the array. Thus, both of the following will save the address of the 0th character in the pointer variable ptr. ptr = str; ptr = &str[0]; strlen() Syntax : len = strlen(ptr); where len is an integer and ptr is a pointer to char strlen() returns the length of a string, excluding the null. The following code will result in len having the value 13. int len; char str[15]; strcpy(str, "Hello, world!"); len = strlen(str); strcpy() Syntax: strcpy(ptr1, ptr2); where ptr1 and ptr2 are pointers to char strcpy() is used to copy a null-terminated string into a variable. Given the following declarations, several things are possible. char S[25];

Fore more detail:- http://www.gurukpo.com

char D[25];

Putting text into a string: strcpy(S, "This is String 1."); Copying a whole string from S to D: strcpy(D, S); Copying the tail end of string S to D: strcpy(D, &S[8]);

N.B. If you fail to ensure that the source string is null-terminated, very strange and sometimes very ugly things may result. Strncpy() Syntax: strncpy(ptr1, ptr2, n); where n is an integer and ptr1 and ptr2 are pointers to char strncpy() is used to copy a portion of a possibly null-terminated string into a variable. Care must be taken because the '\0' is put at the end of destination string only if it is within the part of the string being copied. Given the following declarations, several things are possible. char S[25]; char D[25]; Assume that the following statement has been executed before each of the remaining code fragments.

Putting text into the source string: strcpy(S, "This is String 1."); Copying four characters from the beginning of S to D and placing a null at the end: strncpy(D, S, 4); D[4] = '\0'; Copying two characters from the middle of string S to D: strncpy(D, &S[5], 2); D[2] = '\0'; Copying the tail end of string S to D: strncpy(D, &S[8], 15); which produces the same result as strcpy(D, &S[8]);

strcat()

Fore more detail:- http://www.gurukpo.com

Syntax: strcat(ptr1, ptr2); where ptr1 and ptr2 are pointers to char strcat() is used to concatenate a null-terminated string to end of another string variable. This is equivalent to pasting one string onto the end of another, overwriting the null terminator. There is only one common use for strcat(). char S[25] = "world!"; char D[25] = "Hello, ";

Concatenating the whole string S onto D: strcat(D, S);

N.B. If you fail to ensure that the source string is null-terminated, very strange and sometimes very ugly things may result. strncat() Syntax: strncat(ptr1, ptr2, n); where n is an integer and ptr1 and ptr2 are pointers to char strncat() is used to concatenate a portion of a possibly null-terminated string onto the end of another string variable. Care must be taken because some earlier implementations of C do not append the '\0' at the end of destination string. Given the following declarations, several things are possible, but only one is commonly used. char S[25] = "world!"; char D[25] = "Hello, ";

Concatenating five characters from the beginning of S onto the end of D and placing a null at the end: strncat(D, S, 5); strncat(D, S, strlen(S) -1); Both would result in D containing "Hello, world".

N.B. If you fail to ensure that the source string is null-terminated, very strange and sometimes very ugly things may result. strcmp() Syntax : diff = strcmp(ptr1, ptr2); where diff is an integer and ptr1 and ptr2 are pointers to char strcmp() is used to compare two strings. The strings are compared character by character starting at the characters pointed at by the two pointers. If the strings are identical, the integer value zero (0) is returned. As soon as a difference is

Fore more detail:- http://www.gurukpo.com

found, the comparison is halted and if the ASCII value at the point of difference in the first string is less than that in the second (e.g. 'a' 0x61 vs. 'e' 0x65) a negative value is returned; otherwise, a positive value is returned. Examine the following examples. char s1[25] = "pat"; char s2[25] = "pet"; diff will have a negative value after the following statement is executed. diff = strcmp(s1, s2); diff will have a positive value after the following statement is executed. diff = strcmp(s2, s1); diff will have a value of zero (0) after the execution of the following statement, which compares s1 with itself. diff = strcmp(s1, s1); strncmp() Syntax: diff = strncmp(ptr1, ptr2, n); where diff and n are integers ptr1 and ptr2 are pointers to char strncmp() is used to compare the first n characters of two strings. The strings are compared character by character starting at the characters pointed at by the two pointers. If the first n strings are identical, the integer value zero (0) is returned. As soon as a difference is found, the comparison is halted and if the ASCII value at the point of difference in the first string is less than that in the second (e.g. 'a' 0x61 vs. 'e' 0x65) a negative value is returned; otherwise, a positive value is returned. Examine the following examples. char s1[25] = "pat"; char s2[25] = "pet"; diff will have a negative value after the following statement is executed. diff = strncmp(s1, s2, 2); diff will have a positive value after the following statement is executed. diff = strncmp(s2, s1, 3); diff will have a value of zero (0) after the following statement. diff = strncmp(s1, s2, 1);

Fore more detail:- http://www.gurukpo.com

Q.16. How can we replace single character in a String? Ans.: Single characters can be replaced in a string. Given the following declarations, several things are possible. char str[25] = "cot"; char ch = 'u'; char D[25] = "pat";

Replacing a single character using a char variable: D[1] = ch; This would result in D containing "put". Replacing a single character using a char literal: D[1] = 'e'; This would result in D containing "pet". Replacing a single character using a single character from a string variable: D[1] = str[1]; This would result in D containing "pot".

Q.17. What do you mean by Pattern Matching? Ans.: In computer science, pattern matching is the act of checking for the presence of the constituents of a given pattern. In contrast to pattern recognition, the pattern is rigidly specified. Such a pattern concerns conventionally either sequences or tree structures. Pattern matching is used to test whether things have a desired structure, to find relevant structure, to retrieve the aligning parts, and to substitute the matching part with something else. Sequence (or specifically text string) patterns are often described using regular expressions (i.e. backtracking) and matched using respective algorithms. Sequences can also be seen as trees branching for each element into the respective element and the rest of the sequence, or as trees that immediately branch into all elements.

Fore more detail:- http://www.gurukpo.com

Chapter-5

C++ : Classes and Objects


Q.1. What is C++?
Stroustrup. C++ maintains almost all aspects of the C language, while simplifying memory management and adding several features - including a new datatype known as a class (you will learn more about these later) - to allow object-oriented programming. C++ maintains the features of C which allowed for low-level memory access but also gives the programmer new tools to simplify memory management. C++ used for : C++ is a powerful general-purpose programming language. It can be used to create small programs or large applications. It can be used to make CGI scripts or consoleonly DOS programs. C++ allows you to create programs to do almost anything you need to do. The creator of C++, Bjarne Stroustrup, has put together a partial list of applications written in C++.

Ans.: Released in 1985, C++ is an object-oriented programming language created by Bjarne

Q.2. Ans.:

What is difference between C & C++?


C does not have a class/object concept. C++ provides data abstraction, data encapsulation, Inheritance and Polymorphism. C++ supports all C syntax. In C passing value to a function is "Call by Value" whereas in C++ its "Call by Reference". File extension is .c in C while .cpp in C++.(C++ compiler compiles the files with .c extension but C compiler can not!). In C structures can not have contain functions declarations. In C++ structures are like classes, so declaring functions is legal and allowed. C++ can have inline/virtual functions for the classes. c++ is C with Classes hence C++ while in c the closest u can get to an User defined data type is struct and union.

Q.3.

What is an Object?
behavior.

Ans.: Object is a software bundle of variables and related methods. Objects have state and

Fore more detail:- http://www.gurukpo.com

Q.4.

What is a Class?
problem. After creation the user need not know the specifics of the working of a class.

Ans.: Class is a user-defined data type in C++. It can be created to solve a particular kind of

Q.5.

What is the difference between Class and Structure?


together to perform a particular functionality. But C++ extended the structure to contain functions also. The major difference is that all declarations inside a structure are by default public. Class : Class is a successor of Structure. By default all the members inside the class are private.

Ans.: Structure : Initially (in C) a structure was used to bundle different type of data types

Q.6.

What is the difference between an Object and a Class?


every class contains one or more related objects. A Class is static. All of the attributes of a class are fixed before, during, and after the execution of a program. The attributes of a class don't change. The class to which an object belongs is also (usually) static. If a particular object belongs to a certain class at the time that it is created then it almost certainly will still belong to that class right up until the time that it is destroyed. An Object on the other hand has a limited lifespan. Objects are created and eventually destroyed. Also during that lifetime, the attributes of the object may undergo significant change.

Ans.: Classes and objects are separate but related concepts. Every object belongs to a class and

Q.7.

What is Virtual Class and Friend Class?


access to each other's implementation in ways that the rest of the world shouldn't be allowed to have. In other words, they help keep private things private. For instance, it may be desirable for class DatabaseCursor to have more privilege to the internals of class Database than main() has.

Ans.: Friend classes are used when two or more classes are designed to work together and need

Q.8.

What is the word you will use when defining a function in base class to allow this function to be a Polymorphic Function?

Ans.: Virtual Q.9. What do you mean by Binding of Data and Functions?

Ans.: Encapsulation.

Fore more detail:- http://www.gurukpo.com

Q.10. What is Friend Function? Ans.: As the name suggests, the function acts as a friend to a class. As a friend of a class, it can
access its private and protected members. A friend function is not a member of the class. But it must be listed in the class definition.

Q.11. What is a Scope Resolution Operator? Ans.: A scope resolution operator (::), can be used to define the member functions of a class
outside the class.

Q.12. What do you mean by Inheritance? Ans.: Inheritance is the process of creating new classes, called derived classes, from existing classes
or base classes. The derived class inherits all the capabilities of the base class, but can add embellishments and refinements of its own.

Q.13. What are the advantages of Inheritance? Ans.: It permits code reusability. Reusability saves time in program development. It encourages
the reuse of proven and debugged high-quality software, thus reducing problem after a system becomes functional.

Q.14.

Does c++ support Multilevel and Multiple Inheritance?

Ans.: Yes.
Q.15. What do you mean by Inline Function? Ans.: The idea behind inline functions is to insert the code of a called function at the point where
the function is called. If done carefully, this can improve the application's performance in exchange for increased compile time and possibly (but not always) an increase in the size of the generated binary executables.

Q.16. What are Templates? Ans.1. C++ Templates allow u to generate families of functions or classes that can operate on a variety of different data types, freeing you from the need to create a separate function or class for each type. Using templates, u have the convenience of writing a single generic function or class definition, which the compiler automatically translates into a specific version of the function or class, for each of the different data types that your program actually uses. Many data structures and algorithms can be defined independently of the type of data they work with.

Fore more detail:- http://www.gurukpo.com

You can increase the amount of shared code by separating data-dependent portions from data-independent portions, and templates were introduced to help you do that. Ans.2. Templates allow to create generic functions that admit any data type as parameters and
return value without having to overload the function with all the possible data types. Until certain point they fulfill the functionality of a macro. Its prototype is any of the two following ones : template <class indetifier> function_declaration; function_declaration; template <typename indetifier>

The only difference between both prototypes is the use of keyword class or typename, its use is indistinct since both expressions have exactly the same meaning and behave exactly the same way.

Q.17. What is the difference between Declaration and Definition? Ans.: The declaration tells the compiler that at some later point we plan to present the definition of
this declaration. E.g.: void stars () //function declaration The definition contains the actual implementation. E.g.: void stars () // declarator

{
for(int j=10; j > =0; j--) //function body cout << *; cout << endl; }

Q.18. What is Operator Overloading? Ans.: When an operator is overloaded, it takes on an additional meaning relative to a certain class.
But it can still retain all of its old meanings. Examples : 1) 2) The operators >> and << may be used for I/O operations because in the header, they are overloaded. In a stack class it is possible to overload the + operator so that it appends the contents of one stack to the contents of another. But the + operator still retains its original meaning relative to other types of data.

Q.19. What is Function Overloading and Operator Overloading?


Ans.: Function overloading: C++ enables several functions of the same name to be defined, as long as these functions have different sets of parameters (at least as far as their types are

Fore more detail:- http://www.gurukpo.com

concerned). This capability is called function overloading. When an overloaded function is called, the C++ compiler selects the proper function by examining the number, types and order of the arguments in the call. Function overloading is commonly used to create several functions of the same name that perform similar tasks but on different data types. Operator overloading allows existing C++ operators to be redefined so that they work on objects of user-defined classes. Overloaded operators are syntactic sugar for equivalent function calls. They form a pleasant facade that doesn't add anything fundamental to the language (but they can improve understandability and reduce maintenance costs).

Q.20. Define a Constructor. What it is and how it might be called (2 methods)? Ans.1: constructor is a member function of the class, with the name of the function being the same
as the class name. It also specifies how the object should be initialized. Ways of calling constructor : 1) 2) Implicitly : automatically by complier when an object is created. Calling the constructors explicitly is possible, but it makes the code unverifiable.

Ans.2: class Point2D{


int x; int y; public Point2D() : x(0) , y(0) {} //default (no argument) constructor }; main(){ Point2D MyPoint; // Implicit Constructor call. In order to allocate memory on stack, the default constructor is implicitly called. Point2D * pPoint = new Point2D(); // Explicit Constructor call. In order to allocate memory on HEAP we call the default constructor.

Q.21.

What is Virtual Constructors/Destructors?

Ans.1: Virtual Destructors : If an object (with a non-virtual destructor) is destroyed explicitly by applying the delete operator to a base-class pointer to the object, the base-class destructor function (matching the pointer type) is called on the object.

There is a simple solution to this problem declare a virtual base-class destructor. This makes all derived-class destructors virtual even though they dont have the same name as the base-class destructor. Now, if the object in the hierarchy is destroyed explicitly by applying the delete operator to a base-class pointer to a derived-class object, the destructor for the appropriate class is called. Virtual constructor: Constructors cannot be virtual. Declaring a constructor as a virtual function is a syntax error.

Fore more detail:- http://www.gurukpo.com

Ans.2: Virtual Destructors : If an object (with a non-virtual destructor) is destroyed explicitly by applying the delete operator to a base-class pointer to the object, the base-class destructor function (matching the pointer type) is called on the object. There is a simple solution to this problem declare a virtual base-class destructor. This makes all derived-class destructors virtual even though they dont have the same name as the base-class destructor. Now, if the object in the hierarchy is destroyed explicitly by applying the delete operator to a base-class pointer to a derived-class object, the destructor for the appropriate class is called.

Virtual Donstructor : Constructors cannot be virtual. Declaring a constructor as a virtual function is a syntax error. Q.22. What is Encapsulation? Ans.: Packaging an objects variables within its methods is called encapsulation. Q.23. Explain term Polymorphism and give an example using eg. SHAPE object. If I have a base class SHAPE, how would I define DRAW methods for two objects CIRCLE and SQUARE? Ans.1: Polymorphism : 'Polymorphism' is an object oriented term. Polymorphism may be
defined as the ability of related objects to respond to the same message with different, but appropriate actions. In other words, polymorphism means taking more than one form. Polymorphism leads to two important aspects in Object Oriented terminology - Function Overloading and Function Overriding. Overloading is the practice of supplying more than one definition for a given function name in the same scope. The compiler is left to pick the appropriate version of the function or operator based on the arguments with which it is called. Overriding refers to the modifications made in the sub class to the inherited methods from the base class to change their behavior.

Ans.2: Polymorphism : A phenomenon which enables an object to react differently to the same
function call. In C++ it is attained by using a keyword virtual. Example : public class SHAPE

{
public virtual void SHAPE::DRAW()=0;

}
Note here the function DRAW() is pure virtual which means the sub classes must implement the DRAW() method and SHAPE cannot be instatiated public class CIRCLE::public SHAPE

{
public void CIRCLE::DRAW()

Fore more detail:- http://www.gurukpo.com

// TODO drawing circle

} }
public class SQUARE::public SHAPE

{
public void SQUARE::DRAW()

{
// TODO drawing square

} }
now from the user class the calls would be like globally SHAPE *newShape; When user action is to draw public void MENU::OnClickDrawCircle(){ newShape = new CIRCLE();

}
public void MENU::OnClickDrawCircle(){ newShape = new SQUARE();

}
the when user actually draws public void CANVAS::OnMouseOperations(){ newShape->DRAW();

}
Ans.3: class SHAPE{ public virtual Draw() = 0; //abstract class with a pure virtual method }; class CIRCLE{ public int r; public virtual Draw() { this->drawCircle(0,0,r); } }; class SQURE public int a; public virtual Draw() { this->drawRectangular(0,0,a,a); }

Fore more detail:- http://www.gurukpo.com

}; Each object is driven down from SHAPE implementing Draw() function in its own way.

Q.24. Describe Private, Protected and Public the differences and give examples.

Ans.1: Public, protected and private are three access specifier in C++.
Public data members and member functions are accessible outside the class. Protected data members and member functions are only available to derived classes. Private data members and member functions cant be accessed outside the class. However there is an exception can be using friend classes. Write a function that swaps the values of two integers, using int* as the argument type. void swap(int* a, int*b) { int t; t = *a; *a = *b; *b = t;

}
Ans.2: class Point2D{
int x; int y; public int color; protected bool pinned; public Point2D() : x(0) , y(0) {} //default (no argument) constructor }; Point2D MyPoint; You cannot directly access private data members when they are declared (implicitly) private: MyPoint.x = 5; // Compiler will issue a compile ERROR //Nor yoy can see them: int x_dim = MyPoint.x; // Compiler will issue a compile ERROR On the other hand, you can assign and read the public data members: MyPoint.color = 255; // no problem int col = MyPoint.color; // no problem With protected data members you can read them but not write them: MyPoint.pinned = true; // Compiler will issue a compile ERROR bool isPinned = MyPoint.pinned; // no problem

Fore more detail:- http://www.gurukpo.com

Q.25. Write a Program that ask for user input from 5 to 9 then calculate the average. Ans.: # include "iostream.h"
int main() { int MAX = 4; int total = 0; int average; int numb; for (int i=0; i<MAX; i++) { cout << "Please enter your input between 5 and 9: "; cin >> numb; while ( numb<5 || numb>9) { cout << "Invalid input, please re-enter: "; cin >> numb;

}
total = total + numb;

}
average = total/MAX; cout << "The average number is: " << average << "\n"; return 0;

} Q.26. Write a short code using C++ to print out all odd number from 1 to 100 using a for loop. Ans.: for( unsigned int i = 1; i < = 100; i++ )
if( i & 0x00000001 ) cout << i << \",\";

Send your requisition at


[email protected]

Fore more detail:- http://www.gurukpo.com

You might also like