可以直接调用子函数,方法如下:
(1)在主函数之前定义子函数,在主函数体内可以直接调用.
函数可以调用自身,这叫做函数的递归调用
第一段:基本内容:
C语言中的函数可以递归调用,即:可以直接(简单递归)或间接(间接递归)地自己调自己.
要点:
①.、C语言函数可以递归调用.
第二段:递归条件
采用递归方法来解决问题,必须符合以下三个条件:
①.、可以把要解决的问题转化为一个新问题,而这个新的问题的解决方法仍与原来的解决方法相同,只是所处理的对象有规律地递增或递减.
说明:解决问题的方法相同,调用函数的参数每次不同(有规律的递增或递减),如果没有规律也就不能适用递归调用.
说明:使用其他的办法比较麻烦或很难解决,而使用递归的方法可以很好地解决问题.
说明:一定要能够在适当的地方结束递归调用.不然可能导致系统崩溃.
第三段:递归实例
例:使用递归的方法求n!
当n1时,求n!的问题可以转化为n*(n-1)!的新问题.
源程序:
fac(int n)
{int t;
if(n==1)||(n==0) return 1;
else
{ t=n*fac(n-1);
return t;
}
main( )
{int m,y;
printf("Enter m:");
scanf("%d",m);
if(m0) printf("Input data Error!\n");
{y=fac(m);
printf("\n%d! =%d \n",m,y);
第四段:递归说明
①.、当函数自己调用自己时,系统将自动把函数中当前的变量和形参暂时保留起来,在新一轮的调用过程中,系统为新调用的函数所用到的变量和形参开辟另外的存 储单元(内存空间).每次调用函数所使用的变量在不同的内存空间.
第五段:程序流程
fac(int n) /*每次调用使用不同的参数*/
{ int t; /*每次调用都会为变量t开辟不同的内存空间*/
if(n==1)||(n==0) /*当满足这些条件返回1 */
return 1;
{ t=n*fac(n-1); /*每次程序运行到此处就会用n-1作为参数再调用一次本函数,此处是调用点*/
return t; /*只有在上一句调用的所有过程全部结束时才运行到此处.*/
可以的.
C语言规定,任意函数均可以嵌套调用.所以子函数可以调用其它子函数,也可以调用自身.
如
int?func(int?a)
{
if(a?==?0)?return?0;
return?func(a-1)+a;
这样调用自身的称为递归调用.
又如:
int?fa(int?a)
return?a*a;
int?fb(int?a)
return?fa(a)+fa(a);
这就是不同函数调用的例子.
要知道 C语言是由MAIN函数开始也由它结束.
每调用一次分函数,只要运行完毕后就会回到调用分函数的地方继续往后执行.
C语言主要靠函数调用和return在函数之间切换,很难做到在多层调用中直接返回主函数.虽然goto语句可以无条件跳转,但是必须在同一个函数中使用.
所以呢解决的方法也是用一个特殊的值作为需要返回的标志,然后在两层调用函数中都遇到该值就返回,但是这个方法也有两个前提:
①.)你的两个子函数都是由返回值的函数
同样的操作,C++可以通过异常处理的throw和catch来实现从子函数的子函数直接返回主函数,汇编语言可以用jmp指令跳转实现这个需求.所以呢建议你的这个问题还是用C++ 的异常去解决比较好.
以上就是土嘎嘎小编为大家整理的c语言不能进入子函数相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!