83Plus:Basic:Routines:DecToFrac
From WikiTI
Revision as of 12:42, 10 April 2007 by Calc84maniac (Talk | contribs)
Saibot84's routine:
code ;comment ;K can be any real value 1≠round(fPart(K),9 ;check for calc thinking the fractional part=1 K(Ans)+not(Ans)(1+int(K ;if fPart=1, then Ans=int(K)+1, else, Ans=K {Ans,1→L1 ;L1={numerator,denominator If fPart(L1(1 ;if there's a fPart to the numerator... Then {K→L1 ;leave just the numerator in L1 For(C,0,1 ;initiate a loop If 1=round(fPart(L1(dim(L1))),9 ;if the fPart of the last element of L1=1... 1+int(L1(dim(L1→L1(dim(L1 ;the last element of L1=int(last element of L1)+1 augment(L1,{fPart(L1(dim(L1)))^(-1 ;append the inverse of the fPart(last element of L1) to L1 0→C ;force the For loop to repeat upon next End If L1(dim(L1))=int(round(L1(dim(L1)),9 ;if the last element of L1 is an interger... 1→C ;we do NOT want to repeat the loop End ;to loop or not to loop, that is the question For(C,0,dim(L1)-2 ;for each element of L1, except one... dim(L1)-C ;saving memory and preparing to do the work L1(Ans)L1(Ans-1)→L1(Ans-1 ;multiply the last two elements of L1 together End ;L1(1)=numerator, L1(2)=denominator
calc84maniac's routine:
:{Ans,1,fpart(abs(Ans :While [e]-9<Ans(3 ;[e] is little scientific notation e :{Ans(1),Ans(3),Ans(3)fpart(Ans(2)/Ans(3 :End :round({Ans(1),1}/Ans(2),0