This discussion has been locked.
You can no longer post new replies to this discussion. If you have a question you can start a new discussion

link list

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

Parents
  • "the point I made was that linked lists kill efficiency (which nobody has denied)."

    THAT IS SIMPLY NOT TRUE FOR ALL SITUATIONS.

    I clearly demonstrated, by way of describing a working design, that the code which contained a linked list was efficient; i.e., it fully satisfied the customers requirement
    if "fully satisfied the customers requirement" is your definition of 'effcient' then we are totally talking past each other.

    efficiency, as I stated, can be many things but the efficiency in the case of processor 'throughput' is an absolute.

    If I have made na error in the post that started this rigamarole it is that I used 'efficiency' in the meaning it has to my current (since 8 years) environment, I see from the hoolabaloo that Ishould have said "murder to processor efficiency" or some such.

    If you are making a one-off efficiency in my use is totally irrelevant. if you need $100 worth of 'iron' to save $1000 in design cost, that, of course, is the right approach, but not 'efficient' in my use of the term.

    Erik

Reply
  • "the point I made was that linked lists kill efficiency (which nobody has denied)."

    THAT IS SIMPLY NOT TRUE FOR ALL SITUATIONS.

    I clearly demonstrated, by way of describing a working design, that the code which contained a linked list was efficient; i.e., it fully satisfied the customers requirement
    if "fully satisfied the customers requirement" is your definition of 'effcient' then we are totally talking past each other.

    efficiency, as I stated, can be many things but the efficiency in the case of processor 'throughput' is an absolute.

    If I have made na error in the post that started this rigamarole it is that I used 'efficiency' in the meaning it has to my current (since 8 years) environment, I see from the hoolabaloo that Ishould have said "murder to processor efficiency" or some such.

    If you are making a one-off efficiency in my use is totally irrelevant. if you need $100 worth of 'iron' to save $1000 in design cost, that, of course, is the right approach, but not 'efficient' in my use of the term.

    Erik

Children
  • if "fully satisfied the customers requirement" is your definition of 'effcient' then we are totally talking past each other.

    NO NO NO - That is NOT my definition.

    At the risk of sounding boring, I'll repeat it yet again:

    "You must learn to realise that efficiency is a relative term."

    *** Blink, blink - Mr Ego - Blink, blink ***

  • In the example I cited, I suggested a linked-list precisely because the alternative was so cumbersome!
    for you or for the processor?

    Erik

  • if "fully satisfied the customers requirement" is your definition of 'effcient' then we are totally talking past each other.

    NO NO NO - That is NOT my definition
    then what is?

    Erik

  • "efficiency in the case of processor 'throughput' is an absolute."

    Not really.

    The "processor throughput" depends upon the task at hand:

    Using a linked-list where a simple lookup table would do the job is obviously an inefficent way of achieving the goal;

    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.

    So, efficiency is relative!

    NB: The Linked-list approach to the timers is particularly efficient when there is a large total number of timers, but only a few are actually running at any particular time.

  • "for you or for the processor?"

    Both!

    The alterative was large and cumbersome - so that's a lot of work for the programmer to write, and a lot of work for the processor to execute.

  • "then what is?"

    PLEASE PLEASE PLEASE - Read the posts!

    I'll repeat it yet again:

    "You must learn to realise that efficiency is a relative term."

    Now read it again VERY slowly and VERY carefully.

  • 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.