Help in n factorial!!!
3 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Hello,
Please help me in this question :
"Write a program that reads a nonnegative integer and computes and prints its factorial."
I don't understand the question and even internet doesn't help me either.
Please anyone help me before 11/4/2011.
0 comentarios
Respuestas (6)
rana ali
el 17 de Abr. de 2017
Editada: Walter Roberson
el 8 de Jun. de 2019
n=input('the value of n: ');
f=1;
for i=1:n
f=f*i;
end
disp('factorial is')
disp(f)
2 comentarios
John D'Errico
el 17 de Abr. de 2017
I deleted your virtual duplicate (OTHER) answer. In the future, if you want to modify an answer, then edit it.
Walter Roberson
el 17 de Abr. de 2017
For 23, this code produces 25852016738884978212864 instead of the correct 25852016738884976640000
Matt Fig
el 9 de Abr. de 2011
What do you mean you don't understand the question? I find this very difficult to believe. You know what it is to write a program, right? You know what it is to compute something, then print it? Even if you don't know what a factorial is, the internet surely could help. Here:
Please think it through, do some research, then clarify what you don't understand. Folks here are glad to help when the asker (especially a homework doing asker) puts out some effort and keeps the topic to specific MATLAB questions.
2 comentarios
Dungun_Ganu
el 9 de Abr. de 2011
Editada: Walter Roberson
el 8 de Jun. de 2019
Matt Fig
el 9 de Abr. de 2011
Your code looks good, and Walter points out the infeasibility of fulfilling the requirements as written (or at least as relayed).
I would also point out that naming your M-file FACTORIAL will mask the built-in MATLAB function by the same name.
Walter Roberson
el 9 de Abr. de 2011
Although your proposed code looks good, you will find that it does not produce correct answers for n=18 or above. Your program is required to handle all non-negative integers, not just 1 to 17. You might perhaps be able to negotiate that your program does not have to handle any integers greater than about 10^308.
You are, though, going to run in to considerable difficulties long before that -- for example, (2^27)! is approximately 8.35*10^1032606161 and there aren't enough elementary particles in the Universe to be able to write that number out exactly.
0 comentarios
Mohammed Ali
el 25 de Dic. de 2017
Editada: Image Analyst
el 25 de Dic. de 2017
Write a program to calculate the factorial N!: a. N!=1, N=0 b. N!=N*(N‐1)*(N‐2)...*3*2*1, N>0
n=input('enter n:')
fact=1
if(n==0)
fact=1
for i=n:1:-1
fact=fact*i
end
end
1 comentario
Image Analyst
el 25 de Dic. de 2017
Nope, that won't do it. Did you actually try it?
It's even wrong in more ways than one.
duoduo chen
el 9 de Mayo de 2019
Editada: Walter Roberson
el 9 de Mayo de 2019
n=input('Enter the value of n:');
factorial=1;
if n<0
fprintf('Error!\n');
elseif n==0
factorial=1;
fprintf('factorial=%d\n',factorial);
else
for ii=1:n
factorial=factorial*ii;
end
disp(['factorial=' int2str(factorial)]);
end
3 comentarios
Stephen23
el 9 de Mayo de 2019
Note that the elseif n==0 section is entirely superfluous.
You can start the loop iterations from 2 rather than 1.
As mentioned by Loginatorist eight years ago, the name factorial should be avoided.
YILMAZ TUNAHAN YILMAZ
el 11 de Ag. de 2022
dayı adamsın 3 saattir bununla uğraşıyoruz kralsın bitanesin
Lawrence Liu
el 8 de Jun. de 2019
function val=factorial(n)
if (n==0)
val=1;
else
val=n*factorial(n-1);
end
end
1 comentario
Walter Roberson
el 8 de Jun. de 2019
This will fail when n exceeds 50, giving an error about recursion limit.
It will, as indicated in other responses, start producing incorrect answers long before that.
It will run indefinitely when asked to process a negative input.
Ver también
Categorías
Más información sobre Startup and Shutdown en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!