Data structures help us to organize the data in the computer, resulting in more efficient programs. An efficient program executes faster and helps minimize the usage of resources like memory, disk. Computers are getting more powerful with the passage of time with the increase in CPU speed, availability of faster network and the maximization of disk space. Therefore people have started solving more and more complex problems. As computer applications are becoming complex, so there is need for more resources. This does not mean that we should buy a new computer to make the application execute faster. Our effort should be to ensure that the solution is achieved with the help of programming, data structures and algorithm. We have to analyze the problem to determine the resource constraints that a solution must meet. Suppose, the data is so huge i.e. in Gigabytes (GBs) while the disc space available with us is just 200 Mega bytes. This problem cannot be solved with programming. Rather, we will have to buy a new disk.
Data
Organization
What does
organizing the data mean? It means that the data should be arranged in a way
that it is easily accessible. The data is inside the computer and we want to
see it. We may also perform some calculations on it. Suppose the data contains
some numbers and the programmer wants to calculate the average, standard
deviation etc. May be we have a list of names and want to search a particular
name in it. To solve such problems, data structures and algorithm are used.
Sometimes you may realize that the application is too slow and taking more
time. There are chances that it may be due to the data structure used, not due
to the CPU speed and memory. You may have two data structures and try to decide
which one is more suitable for the resolution of the problem.
A solution is said to be efficient if it solves the
problem within its resource constraints. What does it mean? In the computer, we
have hard disk, memory and other hardware. Secondly we have time. Suppose you
have some program that solves the problem but takes two months. It will be of
no use. Usually, you don’t have this much time and cannot wait for two months.
Suppose the data is too huge to be stored in disk. Here we have also the
problem of resources. This means that we have to write programs considering the
resources to achieve some solution as soon as possible. There is always cost
associated with these resources. We may need a faster and better CPU which can
be purchased. Sometimes, we may need to buy memory. As long as data structures
and programs are concerned, you have to invest your own time for this.
Importance of Data Structure
Each data structure has costs and
benefits. Any data structure used in your program will have some benefits. For
this, you have to pay price. That can be computer resources or the time. Also
keep in mind that you are solving this problem for some client. If the program
is not efficient, the client will not buy it.
In rare cases, a data structure may be
better than another one in all situations. It means that you may think that the
array is good enough for all the problems. Yet this is not necessary. In
different situations, different data structures will be suitable. Sometimes you
will realize that two different data structures are suitable for the problem.
In such a case, you have to choose the one that is more appropriate. An
important skill this course is going to lend to the students is use the data
structure according to the situation. You will learn the programming in a way
that it will be possible to replace the one data structure with the other one
if it does not prove suitable. We will replace the data structure so that the
rest of the program is not affected. You will also have to attain this skill as
a good programmer.
There are three basic things associated
with data structures. A data structure requires:
Ø    Space for each data item it stores
Ø   Time to perform each basic operation
Ø   Programming effort
Understand how to measure the cost of a
data structure or program. These techniques also allow you to judge the merits
of new data structures that you or others might develop. At times, you may have
two suitable data structures for some problem. These can be tried one by one to
adjudge which one is better one. 
Selection of a
Data Structure
It is
necessary to determine the basic operations that must be supported. Quantify
the resource constraints for each operation. Suppose you have to insert the
data in the computer or database and have to search some data item. Let’s take
the example of telephone directory. Suppose there are eight million names in
the directory. Now someone asks you about the name of some particular person.
You want that this query should be answered as soon as possible. You may add or
delete some data. It will be advisable to consider all these operations when
you select some data structure.
Finally select the data structure that meets these
requirements the maximum. Without, sufficient experience, it will be difficult
to determine which one is the best data structure. We can get the help from
internet, books or from someone whom you know for already getting the problems
solved. We may find a similar example and try to use it. After this course, you
will be familiar with the data structures and algorithms that are used to solve
the computer problems.
Now you have selected the data structure. Suppose a
programmer has inserted some data and wants to insert more data. This data will
be inserted in the beginning of the existing data, or in the middle or in the
end of the data. Let’s talk about the arrays and suppose you have an array of
size hundred. Data may be lying in the first fifty locations of this array. Now
you have to insert data in the start of this array. What will you do? You have
to move the existing data (fifty locations) to the right so that we get space
to insert new data. Other way round, there is no space in the start. Suppose
you have to insert the data at 25th location. For this purpose, it is
better to move the data from 26th to
50th locations;
otherwise we will not have space to insert this new data at 25th location.
Now we have to see whether the data can be deleted or
not. Suppose you are asked to delete the data at 27th position. How can we do that? What
will we do with the space created at 27th position?
Thirdly, is all the data processed in some
well-defined order or random access allowed? Again take the example of arrays.
We can get the data from 0th position
and traverse the array till its 50th position. Suppose we want to get the
data, at first from 50th location
and then from 12th. It means that there is no order or sequence. We
want to access the data randomly. Random access means that we can’t say what
will be the next position to get the data or insert the data.
Comparison of Data Structures
How can you decide which data structure is better than other. Firstly, a programmer can do it by writing two programs using different data structure while solving the same problem. Now execute both data structures. One gives the result before the other. The data structure that gives results first is better than the other one. But sometimes, the data grows too large in the problem. Suppose we want to solve some problem having names and the data of names grows to one million. Now when you run both programs, the second program runs faster. What does it mean? Is the data structure used in program one not correct? This is not true. The size of the data, being manipulated in the program can grow or shrink. You will also see that some data structures are good for small data while the others may suit to huge data. But the problem is how can we determine that the data in future will increase or decrease. We should have some way to take decision in this regard. We will study further in other related articles on how to take such decisions.
 
 
The secondary data in marketing research matters a lot where to go for the specific data you need, how to present it, and perform the accurate calculations which will give you everything you need to plan your business.
ReplyDeleteOnline Nursing Assignment Help Service
ReplyDeleteIn the past few years, the demand for Ignou MTTM Project has increased dramatically on the internet. This isn't due to the fact that every student has to meet the expectations academically. These Learners can discover other significant methods to improve their academic standing with the assistance of some expert tutors. You may not have had the assistance previously, so you may not be aware. These professionals add the students with a boost by virtue of their expertise and experience. Additionally, there are many reasons to seek an expert in your Ignou MCOM solved assignments 2021 22 when you are taking classes for an academic degree.
ReplyDelete