Biggest number in computer ever

前端 未结 14 1010
傲寒
傲寒 2021-01-30 09:12

Just asked by my 5 year old kid: what is the biggest number in the computer?

We are not talking about max number for a specific data types, but the biggest number that a

相关标签:
14条回答
  • I think you should be very proud that your 5 year old is already asking questions like this. And you should continue to promote that! This is truly amazing! With that said, I would say that saying Infinity does not count is thinking incorrectly about what numbers mean in computer memory. I feel like this way of thinking is a handicap.

    Mathematicians will never be able to write out ALL the digits of pi or eulers number, BUT we FULLY understand it. Pi, as an example, is perfectly represented by infinite this series: (Pi / 4) = 1 - 1/3 + 1/5 - 1/7 + 1/9 - …
    Just because you literally can’t go to inf. or print every single digit in a console means nothing. You could have printed the symbol representing pi and therefore capturing the inf. series. Computer Algebra Systems (CAS) represent numbers symbolically all the time. Pi, for instance, may be a Symbolic object in memory (the binary in memory did not DIRECTLY represent the number. It represents an "mathematical algorithm" for producing the answer to arbitrary precision). Then you do some math with it, transforming from one expression to the next. At no point in time did we not represent the number COMPLETELY.

    At the end, you can do 2 things with this:

    A) Evaluate the expression, turning it into a number of some kind (or Matrix or whatever). BUT this number could very well be an approximation (say like 20 digits of pi).

    B) Keep it in its symbolic form for reference. Obviously we don’t like staring at symbols because we need to eventually turn the nobs on the apparatii. NOTE: sometimes you can get a finite (non-irrational) number perfectly represented in memory (like number 1) by taking limits or going to inf. Not literally having an inf. number in memory, but symbolically representing it. Just throw this in Wolfram alpha: Lim[Exp[-x], x --> Inf]; It gives you the number 0. Which is EXACT.

    In short:

    It was the HUMANS need to have some binary in memory that DIRECTLY represented the number that caused the number to degrade. Symbolically it was perfectly represented. You could design some algorithm that just continues to calculate the next digits of pi or eulers number giving you an arbitrary amount of precision (Now, this is obviously not practical of course).

    I hope this was at least somewhat useful or interesting to you, even if you disagree =)

    0 讨论(0)
  • 2021-01-30 09:23

    Depends on how much the computer can handle. Although there are some times when the computer can handle numbers greater than (2^(bits-1)-1)... For example: My computer is 64 bit (9223372036854775807), however the calculator that comes with the computer itself can handle numbers of up to 10^9999.

    Many other supercomputers can exceed these limits, and the one with the most memory (bits) might as well be the one with the record (current largest number that can be held by computers).

    Or, if it comes to visually seeing it on computers, you can just make a program that, on monitor, repeats writing 9 and not skips that line to form an ever-growing bunch of 9. :P

    0 讨论(0)
  • 2021-01-30 09:25

    If your hard drive is 1 TB (8'000'000'000'000 bits), and you would print the number that fits on it on paper as hex digits (nobody would do that, but let's assume), that's 2,000,000,000,000 hex digits.

    Each page would contain 4000 hex digits (40 x 100 digits). That's 500,000,000 pages.

    Now stack the pages on top of each other (let's say each page is 0.004 inches / 0.1 mm thick), then the stack would be as 5 km (about 3 miles) tall.

    0 讨论(0)
  • 2021-01-30 09:28

    roughly 2^AVAILABLE_MEMORY_IN_BITS

    EDIT: The above is for actually storing a number and treats all media (RAM, HD, cloud etc.) as memory. Subtracting the OS footprint (measured in KB) doesn't make "roughly" less accurate...

    If you want to "represent" a number in a meaningful way, then you probably want to go with what the CPU provides: unsigned 32 bit integers (roughly 4 Gigs) or unsigned 64 bit integers for most computers your kid will come into contact with.

    NOTE for talking to 5-year-olds: Often, they just want a factoid. Give him a really big and very accurate number (lots of digits), like 4'294'967'295. Then, once the glazing leaves his eyes, try to see how far you can get with explaining how computers represent numbers.

    EDIT #2: I once read this article: Who Can Name the Bigger Number that should provide a whole lot of interesting information for your kid. Obviously he's not your normal five-year-old. So this might get you started in a cool direction about numbers and computation.

    0 讨论(0)
  • 2021-01-30 09:35

    That depends on the datatype you use to represent it. The computer only stores bits (0/1). We, as developers, give the bits meaning. (65 can be a number or the letter A).

    For example, I can define my datatype as 1^N where N is unsigned and represented by an array of bits of arbitrary size. The next person can come up with 10^N which would be ten times larger than my biggest number.

    Sure, there would be gaps but if you don't need them, that doesn't matter.

    Therefore, the question is meaningless since it doesn't have context.

    0 讨论(0)
  • 2021-01-30 09:36

    Errr this is a five year old?

    How about something along the lines of: "I'd love to tell you but the number is so big and would take so long to say, I'd die before I finished telling you".

    0 讨论(0)
提交回复
热议问题