Hello everyone, I am studying link list in c I have a project in which I have lookup table of rpm (clocks used to load the timer used for motor). This rpm table, I am taking in an array Now I want to implement a link list which will access the rpm from table and load it to timer of clock used for running the motor Is it possible Because as I am studying the link list, in that it is mentioned that link list is used instead of array Is it possible to access an array elements using link list ? If yes, then pls suggest me some link for it Correct me if I am wrong Thank u all
But using a linked-list to manage a large number of timers may well be a more efficient approach than any others available - so, in that case, the Linked list is an efficient solution to the problem at hand. OK never say never. We could try a 'programming contest' but to what purpose if 'efficiency' is not measured by the same yardstick by all.
So, efficiency is relative! I disagree efficiency is absolute, what somebodys definition is may be relative. if 'efficiency' means throughput, there is nothing relative, the fastest is the most efficient.
if 'efficiency' means "the most efficient way to get the job done" (as in making a one-off), again it is not relative, the fewest engineering hours is the most efficient
anyhow, Andy, we may have two definitions of 'efficient' and if you by "efficiency is relative" mean that what is the most effcient for job a may or may not be the most efficient for job b I do, of course, agree.
Erik
"I disagree"
What a surprise (not).
On the other hand the measure of stubbornness does appear to be absolute!
"Efficiency" is a measure of the amount of effort expended in getting a job done.
Therefore, if using a linked-list requires less effort than another solution, then the linked list is - by definition - the more efficient approach. Period.
Thus it is not possible to say absolutely and with no context, "linked lists kill effeciency". It depends entirely on the job at hand: just like any other technique, linked lists will be a poor solution to some problems, and a great (and efficient) solution to others.
The key is to use the right tool for the job!
Effeciency of programmer effort (in creating the code) may well differ from efficiency of processor effort (in running the code) which may also differ from efficiency of memory "effort" (in storing the code).
Erik: You still haven't realized that a linked list will (yes not may, but WILL) consume less CPU cycles for some tasks than a vector of pointers or a vector of entries. That is efficient.
That is also an absolute truth. Nothing relative about it. You just can not beat a linked list for some problems. You may not even be able to match it.
But on to another comparison: The car who is the fastest is not always efficient. Some of the fastest racing drivers never makes it to the finish because they are so fast that they fail to turn or break. That is not efficient, even if it is fast.
That a vector algorithm can consume less CPU cycles per iteration does not matter if the vector algorithm needs to do log(n) or n more iterations than a slower algorithm. Such a concept is brutally fast (per step), but brutally stupid - and brutally inefficient and in the end slow! Efficient is time from start to finish, not how fast you can run in circles moving around vector data.
An efficient algorithm almost always wins over efficient code. And a linked list is quite often an efficient method, just as a vector is quite often an inefficient method.
So that means that whenever someone is about to use a vector, you should warn them that they are about to do something inefficient. Using a vector where it shouldn't may result in a need to buy a faster processor, since all the copying (even if just pointers) consumes more bandwidth than the processor can manage - even if DMA is used where applicable. Definitely inefficient!
Switching to assembler wont help either. Wrong algorithm in assembler will loose to the correct algorithm implemented in interpreted basic, when n gets large enough. Donald E. Knuth wouldn't have written all his books about algorithms if that wasn't a fact.
Right now, you are basically warning every carpenter that whenever they pick up a screwdriver (electric or manual) they are inefficient, since they are not using a Hilti nail gun. But it doesn't matter how good a Hilti is to shoot in nails, if the target material breaks. That's fast but inefficient, and the result of using the wrong tool.
Insert to front takes one time (varying for different abstract data types). Insert at the end takes another time. So does searching for a random element. So does sorting. So does removing from head or tail. So does iterating forward. So does iterating backward.
But since a program is never only using one of the above operations, efficiency realy is relative. It is relative to the expected mix of operations. Most of the time, there will not be an absolute efficiency, since there will not be an absolute number of the different operations. As a developer, you have to make guesses how a program/unit will be used. But the absolute time for one iteration step of any of the above cases is totally irrelevant to the final product, since the end result depends on the sum of all iteration steps multiplied by the individual iteration times. Amd fast but stupid often looses.