RAM detection takes two distinct forms:
a) Directly probing RAM every x mb, reading a word, checking to see if this word has already been written to, if not then write a known value and loop through all RAM until the processor loops back to the first x mb, at which point you'll see this unique word when you do the read.
This technique has a number of problems, the biggest being the opportunity of your probe to go over some memory mapped devices and not detect memory holes.
b) Use the interrupt 15h functions to get a memory map from the BIOS. The BIOS knows a heck of a lot more about the motherboard it is installed on than you do. This presents the ever so minor problem of being able to read the memory map format the BIOS returns, but alll round it's better for you.
c) A combination of the two. Use the int 15h functions if available, and the direct probing as a fallback position if they aren't. This is the best of both worlds, but increases code complexity, and the direct probe pitfalls still apply.
As for CPU detection, that's a little simpler:
a) Below 586 you use the presence/absence of various features on the processor to figure out what model/stepping it is (This can get VERY complicated).
b) On 586 and above all the information you require is available via the CPUID instruction. See here
http://osdev.berlios.de/cpuid.html for a longer explanation.
Hope that helps