Variable Number of Input Arguments

8 vues (au cours des 30 derniers jours)
Sai Hitesh Gorantla
Sai Hitesh Gorantla le 1 Fév 2020
My code:
function [too_young] = under_age(age,limit)
if age<21
too_young = true;
else
too_young = false;
end
if age<limit
too_young = true;
else
too_young = false;
end
Getting error when executing
too_young = under_age(20):
Not enough input arguments.
Error in under_age (line 7)
if age<limit
as.png

Réponse acceptée

Ioannis Andreou
Ioannis Andreou le 1 Fév 2020
Modifié(e) : Ioannis Andreou le 1 Fév 2020
If you want variable number of inputs use nargin here
function too_young = under_age(age, limit)
if nargin < 2
limit = 21
end
...

Plus de réponses (4)

Bhaskar R
Bhaskar R le 1 Fév 2020
Modifié(e) : Bhaskar R le 1 Fév 2020
You need provide two inputs but you have provided only one input 20. Give inputs functions as age and limit
[too_young] = under_age(15,21);
%Where 15 is age, 21 is limit
  1 commentaire
somnath paul
somnath paul le 15 Août 2020
In the instruction, it is clearly given that if limit is not given as a input argument then place the default value as 21.
If Code to call my function is
too_young = under_age(20)
Then the function should take the default value now the problem is how to place the default value for matlab.
function too_young = under_age(age,limit)
if nargin<2 && limit == 21
too_young = true
else
too_young = false
end
my answer in above but still they show me errors

Connectez-vous pour commenter.


somnath paul
somnath paul le 15 Août 2020
function too_young = under_age(age,limit)
if nargin == 1
% If number input argument is one then we will consider nargin as 1, that's why nargin == 1.
limit = 21;
if limit > age
too_young = true;
else
too_young = false;
end
end
if nargin == 2
% If number input argument is two then we will consider nargin as 2, that's why nargin == 2.
if limit > age
too_young = true;
else
too_young = false;
end
end
  1 commentaire
Rik
Rik le 15 Août 2020
As you expressed in your comment, the reasoning is to set a value for the limit if it isn't provided. Therefore it doesn't make sense to duplicate the rest of the code as well.

Connectez-vous pour commenter.


PaaKwesi Anderson
PaaKwesi Anderson le 9 Oct 2020
Modifié(e) : Walter Roberson le 29 Mar 2021
function too_young = under_age(age, limit)
if nargin<2
limit=21;
end
if age<limit
too_young = true;
else
too_young = false;
  3 commentaires
PaaKwesi Anderson
PaaKwesi Anderson le 9 Oct 2020
Sorry Sir. Please should I delete it?
Fix the formatting? I don't really get you Sir
Rik
Rik le 9 Oct 2020
If you don't have a good reason to keep this solution, yes, I think you should delete it.
For how to fix the formatting: have a read here.

Connectez-vous pour commenter.


Ganesh Vanave
Ganesh Vanave le 1 Jan 2021
function too_young = under_age(age,limit)
if nargin == 1
limit = 21;
if limit > age
too_young = true;
else
too_young = false;
end
else nargin == 2
if limit > age
too_young = true;
else
too_young = false;
end
end
  1 commentaire
Rik
Rik le 2 Jan 2021
This is a suboptimal setup. You are repeating code, which means any change in algorithm will require you to remember to change two places.
Also, why did you post this answer? What does it teach?

Connectez-vous pour commenter.

Catégories

En savoir plus sur Characters and Strings dans Help Center et File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by