搜档网
当前位置:搜档网 › 素因子分解,C语言,递归

素因子分解,C语言,递归

素因子分解,C语言,递归
素因子分解,C语言,递归

#include

void search( int remainder , int nTerm , int a[] )

{

int i ;

int j ;

j=2 ;

if(nTerm!=0) j=a[nTerm-1] ;//最小因子从上一个所得因子(该因子存在)开始查找

for( ; (j*j<=remainder)&&(remainder%j)!=0 ; j++ ) ;//循环退出条件:找到最小素因子,或者remainder是质数

if(j*j>remainder)//remainder是质数

{

a[nTerm] = remainder ;

}

else//找到素因子

{

a[nTerm] = j ;

search( remainder/j , nTerm+1 , a) ;

}

}

void main()

{

int N ;

int i,j=0 ;

int expon=1 ;

int a[100]={0} ;

for(i=0;i<100;i++)

a[i]=0 ;

printf("请输入正整数:") ;

while(scanf("%d",&N) )

{

for(i=0;i<100;i++)

a[i]=0 ;

search(N,0,a ) ;

printf("%d=", N ) ;

//输出该数组

for( i=0 ; i<100 ; i++ )

{

if(a[i]!=j)

{

if(i&&expon>1) printf("^%d",expon) ;

if(i&&a[i]) printf("*") ;

if(a[i])printf("%d",a[i]) ;

//因当前项与上一项因子不同,指数重置

expon=1 ;

j=a[i];

}

else expon++ ;

if(a[i]==0) break ;

}

printf("\n");

}

}

C语言-函数

C语言(函数,变量作用范围)二 1 C语言程序由函数组成,以下说法正确的是( A ). A)主函数可以在其它函数之前,函数内不可以嵌套定义函数 B)主函数可以在其它函数之前,函数内可以嵌套定义函数 C)主函数必须在其它函数之前,函数内不可以嵌套定义函数 D)主函数必须在其它函数之前,函数内可以嵌套定义函数 2 以下说法中不正确的是( A )。 A) 主函数main中定义的变量在整个文件或程序中有效 B) 不同的函数中可以使用相同名字的变量 C) 形式参数是局部变量 D) 在一个函数内部,可以在复合语句中定义变量,这些变量只在本复合语句中有效 3 下面函数 f(double x) {printf(“%6d\n”,x);} 的类型为( C ). A) 实型B)void 类型C)int 类型 D) A)、B)、C)均不正确 4 以下说法中正确的是( C ). A)C语言程序总是从第一个定义的函数开始执行 B)在C语言程序中,要调用的函数必须在main函数中定义 C)C语言程序总是从main函数开始执行 D)C语言程序中,main函数必须放在程序的开始部分 5 以下正确的函数定义是( C ). A) double fun(int x,int y); {int z; z=x+y; return z;} B) fun(int x,y) {int z; return z;} C) double fun(int x,int y) {double z; z=x+y; return z;} D) double fun( x, y) {int x,y; double z; z=x+y; return z;} 6 定义为void类型的函数,其含义是( A ). A)调用函数后,被调用的函数没有返回值 B)调用函数后,被调用的函数不返回 C)调用函数后,被调用的函数的返回值为任意的类型 D)以上三种说法都是错误的

C语言函数习题及答案

第6章函数习题 一、选择题 1. 一个完整的C源程序是【】。 A)要由一个主函数或一个以上的非主函数构成 B)由一个且仅由一个主函数和零个以上的非主函数构成 C)要由一个主函数和一个以上的非主函数构成 D)由一个且只有一个主函数或多个非主函数构成 2. 以下关于函数的叙述中正确的是【】。 A)C语言程序将从源程序中第一个函数开始执行 B)可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行 C)C语言规定必须用main作为主函数名,程序将从此开始执行,在此结束 D)main可作为用户标识符,用以定义任意一个函数 3. 以下关于函数的叙述中不正确的是【】。 A)C程序是函数的集合,包括标准库函数和用户自定义函数 B)在C语言程序中,被调用的函数必须在main函数中定义 C)在C语言程序中,函数的定义不能嵌套 D)在C语言程序中,函数的调用可以嵌套 4. 在一个C程序中,【】。 A)main函数必须出现在所有函数之前 B)main函数可以在任何地方出现 C)main函数必须出现在所有函数之后 D)main函数必须出现在固定位置 5. 若在C语言中未说明函数的类型,则系统默认该函数的数据类型是【】 A)float B)long C)int D)double 6. 以下关于函数叙述中,错误的是【】。 A)函数未被调用时,系统将不为形参分配内存单元 B)实参与形参的个数应相等,且实参与形参的类型必须对应一致 C)当形参是变量时,实参可以是常量、变量或表达式 D)形参可以是常量、变量或表达式 7. C程序中各函数之间可以通过多种方式传递数据,下列不能用于实现数据传递的方式是【】。 A)参数的形实(哑实)结合 B)函数返回值 C)全局变量 D)同名的局部变量 8. 若函数调用时参数为基本数据类型的变量,以下叙述正确的是【】。 A)实参与其对应的形参共占存储单元 B)只有当实参与其对应的形参同名时才共占存储单元 C)实参与对应的形参分别占用不同的存储单元 D)实参将数据传递给形参后,立即释放原先占用的存储单元 9. 函数调用时,当实参和形参都是简单变量时,他们之间数据传递的过程是【】。 A)实参将其地址传递给形参,并释放原先占用的存储单元 B)实参将其地址传递给形参,调用结束时形参再将其地址回传给实参 C)实参将其值传递给形参,调用结束时形参再将其值回传给实参

二叉树遍历C语言(递归,非递归)六种算法

数据结构(双语) ——项目文档报告用两种方式实现表达式自动计算 专业: 班级: 指导教师: 姓名: 学号:

目录 一、设计思想 (01) 二、算法流程图 (02) 三、源代码 (04) 四、运行结果 (11) 五、遇到的问题及解决 (11) 六、心得体会 (12)

一、设计思想 二叉树的遍历分为三种方式,分别是先序遍历,中序遍历和后序遍历。先序遍历实现的顺序是:根左右,中序遍历实现的是:左根右,后续遍历实现的是:左右根。根据不同的算法分,又分为递归遍历和非递归遍历。 递归算法: 1.先序遍历:先序遍历就是首先判断根结点是否为空,为空则停止遍历,不为空则将左子作为新的根结点重新进行上述判断,左子遍历结束后,再将右子作为根结点判断,直至结束。到达每一个结点时,打印该结点数据,即得先序遍历结果。 2.中序遍历:中序遍历是首先判断该结点是否为空,为空则结束,不为空则将左子作为根结点再进行判断,打印左子,然后打印二叉树的根结点,最后再将右子作为参数进行判断,打印右子,直至结束。 3.后续遍历:指针到达一个结点时,判断该结点是否为空,为空则停止遍历,不为空则将左子作为新的结点参数进行判断,打印左子。左子判断完成后,将右子作为结点参数传入判断,打印右子。左右子判断完成后打印根结点。 非递归算法: 1.先序遍历:首先建立一个栈,当指针到达根结点时,打印根结点,判断根结点是否有左子和右子。有左子和右子的话就打印左子同时将右子入栈,将左子作为新的根结点进行判断,方法同上。若当前结点没有左子,则直接将右子打印,同时将右子作为新的根结点判断。若当前结点没有右子,则打印左子,同时将左子作为新的根结点判断。若当前结点既没有左子也没有右子,则当前结点为叶子结点,此时将从栈中出栈一个元素,作为当前的根结点,打印结点元素,同时将当前结点同样按上述方法判断,依次进行。直至当前结点的左右子都为空,且栈为空时,遍历结束。 2.中序遍历:首先建立一个栈,定义一个常量flag(flag为0或者1),用flag记录结点的左子是否去过,没有去过为0,去过为1,默认为0.首先将指针指向根结点,将根结点入栈,然后将指针指向左子,左子作为新的结点,将新结点入栈,然后再将指针指向当前结点的左子,直至左子为空,则指针返回,flag置1,出栈一个元素,作为当前结点,打印该结点,然后判断flag,flag为1则将指针指向当前结点右子,将右子作为新的结点,结点入栈,再次进行上面的判断,直至当前结点右子也为空,则再出栈一个元素作为当前结点,一直到结束,使得当前结点右子为空,且栈空,遍历结束。 3.后续遍历:首先建立两个栈,然后定义两个常量。第一个为status,取值为0,1,2.0代表左右子都没有去过,1代表去过左子,2,代表左右子都去过,默认为0。第二个常量为flag,取值为0或者1,0代表进左栈,1代表进右栈。初始时指针指向根结点,判断根结点是否有左子,有左子则,将根结点入左栈,status置0,flag置0,若没有左子则判断结点有没有右子,有右子就把结点入右栈,status置0,flag置1,若左右子都没有,则打印该结点,并将指针指向空,此时判断flag,若flag为0,则从左栈出栈一个元素作为当前结点,重新判断;若flag为1则从右栈出栈一个元素作为当前结点,重新判断左右子是否去过,若status 为1,则判断该结点有没有右子,若有右子,则将该结点入右栈,status置1,flag置1,若没有右子,则打印当前结点,并将指针置空,然后再次判断flag。若当前结点status为2,且栈为空,则遍历结束。若指针指向了左子,则将左子作为当前结点,判断其左右子情况,按上述方法处理,直至遍历结束。

c语言递归算法实现数列全排列

1、数列全排列递归算法; 2、在不打印所有全排列时,数列长度分别为10、11、12、13时全排列花费时间测试,修改N的值重新编译即可运行测试; 3、如果需要打印全排列,打开perm函数中的注释掉的两行printf语句即可。

#include #define N 10 int a[20] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20}; void swap(int one, int two) { int tmp = a[one]; a[one] = a[two]; a[two] = tmp; } void perm(int *list, int begin, int end)

{ int i = 0; if (begin == end){ for ( i = 0; i < N ; i++){ //printf("%d", list[i]); } //printf("\n"); } else{ for (i = begin; i <= end; i++) { swap(begin,i); perm(list,begin+1,end); swap(begin,i); } } } int main(int argc, char *argv[]) { int *list=a; int i; perm(list, 0, N-1); for (i = 0; i < N; i++){ printf("%d", list[i]); } return 0; }

C语言函数递归[1]

递归,作为C语言最经典的算法之一,是一种非常有用的程序设计方法。虽然用递归算法编写的程序结构清晰,具有很好的可读性,还往往使某些看起来不易解决的问题变得容易解决。但在递归函数中,由于存在着自调用过程,程序控制反复进入其自身,使程序的分析设计有一定困难,致使很多初学者往往对递归迷惑不解,也在这上面花了不少的时间,却收效甚微。那么,究竟什么是递归?怎么实现递归呢? 所谓递归,简而言之就是在调用一个函数的过程中又直接或间接地调用该函数本身,以实现层次数据结构的查询和访问。在函数中直接调用函数本身,称为直接递归调用。在函数中调用其它函数,其它函数又调用原函数,这就构成了函数自身的间接调用,称为间接递归调用。 而采用递归方法来解决问题,必须符合以下三个条件: 1、可以把要解决的问题转化为一个新问题,而这个新的问题的解决方法仍与原来的解决方法相同,只是所处理的对象有规律地递增或递减。 说明:解决问题的方法相同,调用函数的参数每次不同(有规律的递增或递减),如果没有规律也就不能适用递归调用。 2、可以应用这个转化过程使问题得到解决。 说明:使用其他的办法比较麻烦或很难解决,而使用递归的方法可以很好地解决问题 3、必定要有一个明确的结束递归的条件。 说明:一定要能够在适当的地方结束递归调用。不然可能导致系统崩溃。 好知道是这样以后;我们来写一个众多教材上的程序:使用递归的方法求n!。 当n>1时,求n!的问题可以转化为n*(n-1)!的新问题。比如n=4: 第一部分:4*3*2*1 n*(n-1)! 第二部分:3*2*1 (n-1)(n-2)! 第三部分:2*1 (n-2)(n-3)! 第四部分:1 (n-4)! 4-4=0,得到值1,结束递归。 我给的源程序如下: #include int fac(int n) {int c; printf("now the number is %d ",n); getchar(); if(n==1 || n==0) c=1; else c=n*fac(n-1); printf("now the number is %d and the %d! is %d",n,n,c); getchar();

C语言(迭代法与递归法)

一、用迭代法求斐波那契数列。 #include #define N 35 //定义输出项数 int main() { int f1=1,f2=1,f3=0; int i; int n=2; printf("Fibonacci数列的前%d项为:\n",N); printf("%d\t%d\t",f1,f2); for(i=3;i #include double factorial(double x) { double amass; if(x==0||x==1) amass=1; else amass=factorial(x-1)*x; //递归法求X的阶乘return amass; } int main() { double sum=0; double n=1; int sign=1; double x;

printf("输入sin(x)中的x:\n"); scanf("%lf",&x); do { sum=sum+sign*pow(x,n)/factorial(n); n=n+2; sign=-sign; }while(pow(x,n)/factorial(n)>=1e-6); printf("sin(%.2lf)=%.2lf\n",x,sum); return 0; }

c语言递归函数示例

1.编写计算X的Y次幂的递归函数getpower(int x,int ),并在主程序中实现输入输出。#include"stdio.h" long getpower(int x,int y) { if(y==1) return x; else return x*getpower(x,y-1); } void main() { int num,power; long answer; printf("please input a number:"); scanf("%d",&num); printf("please input the number's power series:"); scanf("%d",&power); answer=getpower(num,power); printf("结果是:%ld\n",answer); } 结果说明:输入61再输入5求得61的5次幂为844596301. 2编写计算学生年龄的递归函数。 #include int age(int n) { int c; if(n==1) c=10; else c=age(n-1)+2; return c; } void main() { int n=5; printf("the five student'sage is:%d years old\n",age(n)); }

结果说明:第五个学生的年龄为18岁。 3.编写递归函数实现Ackman函数。 #include Acm(int m,int n) { if(m==0) return n+1; else if(n==0) return Acm(m-1,1); else return Acm(m-1,Acm(m,n-1)); } int main() { printf("Acm(2,1)=%d\n",Acm(2,1)); printf("Acm(3,2)=%d\n",Acm(3,2)); return 0; } 结果说明:利用递归函数求得Acm(2,1)=5,Acm(3,2)=29. 实验小结:

c语言递归详细解答(C language recursive detailed answer)

c语言递归详细解答(C language recursive detailed answer)Erudite, questioning, deliberative, discernment, and faithful. It is the southern landscape, end of spring again. Alone, body and shadow comforting each other. Cai Feng Shuangfei body without wings, heart to heart. Ruthless is not really heroic, pity son how not husband?. recursion Recursion is a powerful tool for designing and describing algorithms, as it is often used in the description of complex algorithms, and for this reason, it is discussed before further introducing other algorithms. Can the recursive algorithms described usually has such features: in order to solve the problem of size N, try to break it down into smaller problems, and then from these small solutions facilitate the construction of a big problem solution, and these smaller problems can also use the same decomposition and synthesis method, decomposition the smaller problems, and from the deconstruction of create larger scale problems in solving these problems less. In particular, when the scale is N=1, it can be solved directly. [PROBLEMS] written to calculate Fibonacci (Fibonacci) n function FIB sequence (n). Fibonacci Numbers: 0, 1, 1, 2, 3,...... Namely: FIB (0) =0; FIB (1) =1;

C语言函数练习题及答案

1 【单选题】 在下列关于C函数定义的叙述中,正确的是??A、 函数可以嵌套定义,但不可以嵌套调用; ? ?B、 函数不可以嵌套定义,但可以嵌套调用; ? ?C、 函数不可以嵌套定义,也不可以嵌套调用; ? ?D、 函数可以嵌套定义,也可以嵌套调用; ? 我的答案:B得分:2.5分 2 【单选题】 下面函数调用语句含有实参的个数为? nc((exp1,exp2),(exp3,exp4,exp5)); ?A、 1 ? ?B、 2

? ?C、 4 ? ?D、 5 ? 我的答案:B得分:2.5分 3 【单选题】 C语言中函数返回值的类型是由以下哪个选项决定的??A、 函数定义时指定的类型; ? ?B、 return语句中的表达式类型; ? ?C、 调用该函数时的实参的数据类型; ? ?D、 形参的数据类型; ? 我的答案:A得分:2.5分 4 【单选题】

以下关于函数叙述中,错误的是? ?A、 函数未被调用时,系统将不为形参分配内存单元; ? ?B、 实参与形参的个数必须相等,且实参与形参的类型必须对应一致; ? ?C、 当形参是变量时,实参可以是常量、变量或表达式; ? ?D、 如函数调用时,实参与形参都为变量,则这两个变量不可能共享同一内存空间; ? 我的答案:B得分:2.5分 5 【单选题】 若函数调用时参数为基本数据类型的变量,以下叙述正确的是? ?A、 实参与其对应的形参共享内存存储单元; ? ?B、 只有当实参与其对应的形参同名时才共享内存存储单元; ? ?C、 实参与对应的形参分别占用不同的内存存储单元; ?

实参将数据传递给形参后,立即释放原先占用的内存存储单元; ? 我的答案:C得分:2.5分 6 【单选题】 函数调用时,实参和形参都是简单变量,它们之间数据传递的过程描述正确的是??A、 实参将地址传递给形参,并释放原先占用的存储单元; ? ?B、 实参将地址传递给形参,调用结束时形参再将此地址回传给实参; ? ?C、 实参将值传递给形参,调用结束时形参再将其值回传给实参; ? ?D、 实参将值传递给形参,调用结束时形参并不将其值回传给实参; ? 我的答案:D得分:2.5分 7 【单选题】 若用数组名作为函数调用的实参,则传递给形参的是? ?A、 数组第一个元素的地址; ?

C语言程序设计 递归应用举例

7.3.3递归应用举例 【例7-6】求Fibonacci数列第n项的值。Fibonacci数列以1,1开头,以后每一项都是前两项之和。 1,1,2,3,5,8,13,21…… 程序设计思路: (1)求Fibonacci数列第n项的值可用递归形式定义为: fibonacci(0)=1 fibonacci(1)=1 fibonacci(n)=fibonacci(n-1)+fibonacci(n-2) 上述定义将求解第n项化简为求解第n-1和n-2项,求解在规模上缩小了,但求解的方法是一致的。 (2)定义fibonacci函数计算第n项的值 int fibonacci(int n) { if(n==0||n==1) return1; else return fibonacci(n–1)+fibonacci(n–2); } (3)由于fibonacci数列增长很快,因此fibonacci函数返回值定义为long。 参考程序如下: /*程序名:7_6.c*/ /*功能:求Fibonacci数列第n项的值*/ #include int fibonacci(int); int main() { int n; printf("请输入一个整数:"); scanf("%d",&n); printf("Fibonacci(%d)=%ld",n,fibonacci(n)); return0; } int fibonacci(int n)/*递归函数的定义*/ { if(n==0||n==1)

return1; else return fibonacci(n-1)+fibonacci(n-2); } 程序运行结果:(分别运行4次程序) 请输入一个整数:10 Fibonacc(10)=55 请输入一个整数:10 Fibonacc(20)=6765 请输入一个整数:20 Fibonacc(25)=75025 请输入一个整数:30 Fibonacc(30)=832040 【例7-7】计算两个整数的最大公约数。 程序设计思路:利用辗转相除法计算两个整数的最大公约数的算法如下: (1)如果x除以y的余数为0,则y即为最大公约数,返回y值,算法结束。 (2)如果x除以y的余数不为0,则用y和x%y做参数再重复求最大公约数。反复进行(1)、(2)的操作。 例如x=341,y=132,341除以132,商是2,余数为77,因为余数≠0,所以置x=132,y=77,依次类推,最后22除以11时,余数为0,算法终止,132和341的最大公因数是11。 参考程序如下: /*程序名:7_7.c*/ /*功能:求两个整数的最大公约数*/ #include int gcd(int,int); int main() { int a,b; printf("请输入两个整数:"); scanf("%d,%d",&a,&b); printf("%d,%d的最大公约数是%d",a,b,gcd(a,b)); return0; } int gcd(int x,int y) { if(x%y==0) return y; else

c语言_递归下降分析程序实验_共13页

实验二递归下降语法分析程序的设计与实现 、实验目的:加深对语法分析器工作过程的理解;加强对递归下降法实现语法分析程序的掌握;能够采用一种编程语言实现简单的语法分析程序;能够使用自己编写的分析程序对简单的程序段进行语法翻译。 、实验内容:在实验1的基础上,用递归下降分析法编制语法分析程序,语法分析程序的实现可以采用任何一种编程工具。 三、实验要求: 1.对语法规则有明确的定义; 2.编写的分析程序能够进行正确的语法分析; 3.*对于遇到的语法错误,能够做出简单的错误处理,给出简单的错误提示,保证顺利完成语法分析过程; 4.实验报告要求用文法的形式对语法定义做出详细说明,说明语法分析程序的工作过程,说明错误处理的实现*。 四、实验学时:4学时 五、实验步骤: 1.定义目标语言的语法规则; 2.根据语法规则输入语句段,用递归下降分析的方法进行语法分析,直到结束; 3.*对遇到的语法错误做出错误处理。 六、实验内容: 1.编程实现给定文法的递归下降分析程序。 E—T|E+T T—F|T*F F—(E)|i

2.(参考课本P74)对文法先进行消除左递归。 3.分析程序由一组递归过程组成,文法中每个非终结符对应一个过程几个全局过程和变量: ADVANCE,把输入串指示器IP指向下一个输入符号,即读入一个单字符号 SYM,IP当前所指的输入符号 ERROR,出错处理子程序 每个非终结符有对应的子程序的定义,首先在分析过程中,当需要从某个非终结符出发进行展开(推导)时,就调用这个非终结符对应的子程序。 4.具体实现时: 当遇到终结符,编写:if (当前读到的输入符号=i) 读入下一个输入符号 当遇到非终结符E时,编写语句:调用E() 当遇到E-->编写语句if (当前读到的输入符号不属于Follow (E)) Error(); (4)当某个非终结符的规则有多个候选式时,按LL(1)文法的条件能唯一的选择一个候选式进行推导。 #in elude using n ames pace std; char 〃字符串的存入 a[80]; char sym; 〃单个的判断字符 int //字符串下标 i=0; void //功能识别函数 E(); void //功能识别函数 E2(); void //功能识别函数 T(); void //功能识别函数 T2();

c语言函数

用递归法将一个正整数n的各个数字分别输出int f(int num) { int x; if(num==0) return 0; else{ x=num%10;

f(num/10); } 穷举实例 int main() { int n=1,m,sum,i; while(1) { m=n; sum=0; for(i=1;i<8;i++) { m=m*2; sum=m+sum; } sum=sum+n; if(sum==765) { cout<<"fist"<

break; } n++; } return 0; } 宏定义可以定义函数例如交换函数swap #Define swap(a,b){int c;c=a;a=b;b=c;} 简单结构体成员号码姓名 #include "StdAfx.h" #include"stdio.h" #include"string.h"

#include"iostream" using namespace std; struct student { int num; char name[50]; struct student *next; }; struct student *creat(int n) { int i; struct student *head,*p1,*p2; int num1; char name1[50]; head=NULL; for(i=n;i>0;--i) { p1=(struct student* )malloc(sizeof(struct student)); cout<<"输入编号";

C语言递归练习(附答案)

dic递归基础练习题: 1.求1+2+3+……+n的值 int sum(int a,int b) { if(b==a) return a; return a+sum(a+1,b); } 2. 求1*2*3*……*n的值 cheng(int begin,int end) { if(begin==end) return begin; return begin * cheng(begin+1,end); } 3. 数的全排列问题。将n个数字1,2,…n的所有排列按字典顺序枚举出猴 2 3 1 2 1 3 3 1 2 3 2 1 4. 数的组合问题。从1,2,…,n中取出m个数,将所有组合按照字典顺序列出。 如n=3,m=2时,输出: 1 2 1 3 2 3 5. 小猴子第一天摘下若干桃子,当即吃掉一半,又多吃一个.第二天早上又将剩下的桃子吃一半,又多吃一个.以后每天早上吃前一天剩下的一半另一个.到第10天早上猴子想再吃时发现,只剩下一个桃子了.问第一天猴子共摘多少个桃子? fruit(int begin,int times) { if(times==10) return begin; return fruit((begin+1)*2,times+1); } 6. 有雌雄一对兔子,假定过两个月便可繁殖雌雄各一的一对小兔子。问过n个月后共有多少对兔子? 7. 一个人赶着鸭子去每个村庄卖,每经过一个村子卖去所赶鸭子的一半又一只。这样他经过了七个村子后还剩两只鸭子,问他出发时共赶多少只鸭子?经过每个村子卖出多少只鸭子? duck(int begin,int times) { if(times==7) return begin; return duck((begin+1)*2,times+1); }

C语言函数练习题及答案

C语言函数练习题及答案

1 【单选题】 在下列关于C函数定义的叙述中,正确的是? ?A、 函数可以嵌套定义,但不可以嵌套调用; ? ?B、 函数不可以嵌套定义,但可以嵌套调用; ? ?C、 函数不可以嵌套定义,也不可以嵌套调用; ? ?D、 函数可以嵌套定义,也可以嵌套调用; ? 我的答案:B得分:2.5分 2 【单选题】 下面函数调用语句含有实参的个数为? nc((exp1,exp2),(exp3,exp4,exp5));

?A、 1 ? ?B、 2 ? ?C、 4 ? ?D、 5 ? 我的答案:B得分:2.5分 3 【单选题】 C语言中函数返回值的类型是由以下哪个选项决定的? ?A、 函数定义时指定的类型; ? ?B、

return语句中的表达式类型; ? ?C、 调用该函数时的实参的数据类型; ? ?D、 形参的数据类型; ? 我的答案:A得分:2.5分 4 【单选题】 以下关于函数叙述中,错误的是? ?A、 函数未被调用时,系统将不为形参分配内存单元; ? ?B、 实参与形参的个数必须相等,且实参与形参的类型必须对应一致; ? ?C、 当形参是变量时,实参可以是常量、变量或表达式; ?

?D、 如函数调用时,实参与形参都为变量,则这两个变量不可能共享同一内存空间; ? 我的答案:B得分:2.5分 5 【单选题】 若函数调用时参数为基本数据类型的变量,以下叙述正确的是? ?A、 实参与其对应的形参共享内存存储单元; ? ?B、 只有当实参与其对应的形参同名时才共享内存存储单元; ? ?C、 实参与对应的形参分别占用不同的内存存储单元; ? ?D、 实参将数据传递给形参后,立即释放原先占用的内存存储单元; ? 我的答案:C得分:2.5分

C语言实验报告,含递归(带程序)

一、写一个函数int digit(int n,int k),它返回数n的从右边向左的第k个十进数字位值。例如,函数调用digit(1234,2)将返回值3。 二、写一个函数int isprime(int n),当n是质数时,函数返回非零值;当n是合数时,函数返回零值。 三、写一个函数reverse(char s[]),将字符串s[]中的字符存储位置颠倒后重新存于s[]中。试分别用递归和非递归两种形式编写。 四、写一个主函数输入测试数据(自己指定),并调用上述函数,检查函数功能的正确性。要求:把预备知识、步骤、程序框图、调试好的程序及存在的问题写在下面(不够可以附页)。 #include #include int digit(int n,int k); int isprime(int n); void reverse(char s[]); //非递归实现 void reverse1(char s[]); //递归实现 int digit(int n,int k) { int m1,m2,i; m1=n; m2=0; while(m1!=0) //统计n数字的位数 { m1=m1/10; m2=m2+1; } if(k<=0||k>m2) return 0; //不能正确截取 m1=n; for(i=1;in/2) return 1; else

C语言程序设计 递归调用的概念

7.3.1递归调用的概念 函数的递归调用指的是一个函数执行过程中出现了直接或间接调用函数本身的调用方式。如果直接调用函数本身称为直接递归;如果调用了另外一个函数,那个函数又调用该函数,则称为间接递归。 递归方法的基本思想是将一个问题向下分解具有同样解决方法但规模不断缩小的子问题,不断进行这样的分解,直到分解的子问题有一个已知解。下面通过一个例子来讲解递归的概念。 例如,某数列为k(n)的定义为: 1n=1 k(n)=2×k(n-1)n为偶数 3×k(n-1)n为奇数 求该数列的第四项k(4)。 从以上数列的定义来看,该数列的任何一项均受前一项的约束,在求解k(4)时,首先要求解k(3),要求解k(3)就必须先知道k(2)的值,k(2)的值取决于k(1)的值。由于k(1)的值是已知的,然后再由k(1)反推回去计算k(2),k(3),k(4),得到K(4)的值。求解过程可以用图7-2表示。 k(4)=k(3)×2 k(3)=k(2)×3 k(2)=k(1)×2 k(1)=1k(2)=1×2=2 k(3)=2×3=6 k(4)=6×2=12 图7-2回推和递推过程 从图7-2可以看出,求解过程分为两个阶段:第一阶段是“回推”,将第4个值表示为第3个值的函数,将第3个值表示为第2个值的函数,再回推到第1个,而k(1)是已知的,到达了递归的边界。第二阶段使用“递推”,从已知的第1个值推出第2个值,从第2个值推出第3个值,从第3个值就推出了第4个值。整个的回推和递推过程就称为递归过程。 可以用一个函数描述上面的递归过程: int k(int n)/*递归计算函数*/ { int m;/*m存放函数的返回值*/ if(n==1)m=1; else if(n%2==0)m=k(n-1)*2;/*调用自身,n为偶数*/ else m=k(n-1)*3;/*调用自身,n为奇数*/ return(m);

二叉树遍历C语言递归非递归六种算法

二叉树遍历C语言(递归-非递归)六种算法

————————————————————————————————作者:————————————————————————————————日期:

数据结构(双语) ——项目文档报告用两种方式实现表达式自动计算 专业: 班级: 指导教师: 姓名: 学号:

目录 一、设计思想 (01) 二、算法流程图 (02) 三、源代码 (04) 四、运行结果 (11) 五、遇到的问题及解决 (11) 六、心得体会 (12)

一、设计思想 二叉树的遍历分为三种方式,分别是先序遍历,中序遍历和后序遍历。先序遍历实现的顺序是:根左右,中序遍历实现的是:左根右,后续遍历实现的是:左右根。根据不同的算法分,又分为递归遍历和非递归遍历。 递归算法: 1.先序遍历:先序遍历就是首先判断根结点是否为空,为空则停止遍历,不为空则将左子作为新的根结点重新进行上述判断,左子遍历结束后,再将右子作为根结点判断,直至结束。到达每一个结点时,打印该结点数据,即得先序遍历结果。 2.中序遍历:中序遍历是首先判断该结点是否为空,为空则结束,不为空则将左子作为根结点再进行判断,打印左子,然后打印二叉树的根结点,最后再将右子作为参数进行判断,打印右子,直至结束。 3.后续遍历:指针到达一个结点时,判断该结点是否为空,为空则停止遍历,不为空则将左子作为新的结点参数进行判断,打印左子。左子判断完成后,将右子作为结点参数传入判断,打印右子。左右子判断完成后打印根结点。 非递归算法: 1.先序遍历:首先建立一个栈,当指针到达根结点时,打印根结点,判断根结点是否有左子和右子。有左子和右子的话就打印左子同时将右子入栈,将左子作为新的根结点进行判断,方法同上。若当前结点没有左子,则直接将右子打印,同时将右子作为新的根结点判断。若当前结点没有右子,则打印左子,同时将左子作为新的根结点判断。若当前结点既没有左子也没有右子,则当前结点为叶子结点,此时将从栈中出栈一个元素,作为当前的根结点,打印结点元素,同时将当前结点同样按上述方法判断,依次进行。直至当前结点的左右子都为空,且栈为空时,遍历结束。 2.中序遍历:首先建立一个栈,定义一个常量flag(flag为0或者1),用flag记录结点的左子是否去过,没有去过为0,去过为1,默认为0.首先将指针指向根结点,将根结点入栈,然后将指针指向左子,左子作为新的结点,将新结点入栈,然后再将指针指向当前结点的左子,直至左子为空,则指针返回,flag置1,出栈一个元素,作为当前结点,打印该结点,然后判断flag,flag为1则将指针指向当前结点右子,将右子作为新的结点,结点入栈,再次进行上面的判断,直至当前结点右子也为空,则再出栈一个元素作为当前结点,一直到结束,使得当前结点右子为空,且栈空,遍历结束。 3.后续遍历:首先建立两个栈,然后定义两个常量。第一个为status,取值为0,1,2.0代表左右子都没有去过,1代表去过左子,2,代表左右子都去过,默认为0。第二个常量为flag,取值为0或者1,0代表进左栈,1代表进右栈。初始时指针指向根结点,判断根结点是否有左子,有左子则,将根结点入左栈,status置0,flag置0,若没有左子则判断结点有没有右子,有右子就把结点入右栈,status置0,flag置1,若左右子都没有,则打印该结点,并将指针指向空,此时判断flag,若flag为0,则从左栈出栈一个元素作为当前结点,重新判断;若flag为1则从右栈出栈一个元素作为当前结点,重新判断左右子是否去过,若status 为1,则判断该结点有没有右子,若有右子,则将该结点入右栈,status置1,flag置1,若没有右子,则打印当前结点,并将指针置空,然后再次判断flag。若当前结点status为2,且栈为空,则遍历结束。若指针指向了左子,则将左子作为当前结点,判断其左右子情况,按上述方法处理,直至遍历结束。

C语言函数定义、调用,递归函数

C语言程序设计实验报告 实验5 函数程序设计 班级学号姓名 一、实验目的 (1)掌握C语言函数定义及调用的规则; (2)掌握递归函数的编写方法和运行过程; (3)理解变量的作用域和生存期。 二、补充知识: 怎样模拟计算机“想”一个数呢?用随机函数rand() 产生[0,RAND_MAX] 之间的随机数magic = rand();RAND_MAX是在stdlib.h中定义,不大于双字节整数的最大值32767 ,所以使用前加 #include 产生[0,b-1] 之间的随机数 ◆magic = rand()%b; 产生[a,a+b-1] 之间的随机数 ◆magic = rand()%b + a; rand()产生的数据是一串伪随机序列,要实现真正的随机化,用srand()函数播种种子: ◆#include ◆srand(time(NULL)); ◆magic = rand() % 100 + 1; 二、实验内容及步骤 1、程序改错 输入已编好的源程序,源程序中包含有错误,先对源程序进行编译和连接,然后根据提示信息,修改程序中的错误,经过多次修改—编译—连接,直到编译、连接成功。最后运行程序,输出正确结果。 (1)下述程序中,函数FUN功能是:计算正整数NUM的各位上的数字之积。例如,若输入252,则输出应该是20;若输入202,则输出应该是0。 #include /*提示:有3处错误*/ #include long fun(num) {long k=1; do {k*=num%10; num\=10; }while (num) return k; } void main() {long n; scanf(“%ld”,&n); printf(“\n%ld\n”,fun(n)); }

C语言初学者如何更容易的理解递归

C语言初学者如何更容易的理解递归。 题外:目前在学习Stephen Prata的《C Primer Plus》。最初决定学习C时,先通读了谭浩强老师的《C程序设计(第四版)》两遍,毕竟此书是很多高校C语言的学习教材,C的特点及基本的语法已有所了解。于是兴致勃勃的找了几个C开发的案例来看,结果是一脸懵逼。感觉《C程序设计》一书中只是讲解了C最基本的知识点,一些比较深入的内容并没有涉及。于是有了再看看其他C语言类书籍的念头,《C Primer Plus》出现了(双十一老马家买的,巨便宜。。。窃喜。。。)。 目前又学到递归,其实结合谭老师《C程序设计》内的讲解,根据实例程序的运行结果,这一部分能理解,但有些牵强,总有种不上不下、半吊子的感觉,理解非常不深入,更谈不上灵活运用。 于是逛论坛、看帖子不亦乐乎,上网搜各种关于递归的讲解。 生硬滴转入正题。 看例子。 谭老师用的汉诺塔例子就比较经典,很多人应该都玩过这个小游戏,很容易理解。 有一个老和尚戒懒想把64个盘子借助B座从A座移到C座,规定每次只能移动一个盘,且在移动过程中在3个座上都始终保持大盘在下,小盘在上。 “递归”顾名思义,递:传递,传递的是什么呢?就是将复杂问题一步步传递给简单问题,直到最简单的解决方法。戒懒就是用的这种传递方法,找第2个和尚戒色将上面的63个盘子从一个座移到另一个座,那戒懒只需要移动第64个盘子就可以了,问题就解决了。 梳理一下: ①第2个和尚戒色将63个盘子从A座移到B座(不管他用什么方法,反正就是移过去了); ②戒懒将第64个盘子从A座移到C座; ③再让戒色将63个盘子从B座移到C座。 同理,第2个和尚戒色找了第3个和尚戒酒来移动62个盘子,第3个和尚戒酒找了第4个和尚戒烟移动61个盘子,以此类推,一个个传递下去,最终找的第64个和尚断奶只需要能移动1个盘子即可。 至于“归”,就是回来。就是从最简单的解决方法一步步返回,直到最终解决问题。也就是第64个和尚断奶完成移动1个盘子,使第63个和尚戒糖能成功移动2个盘子,再使第62个和尚戒怒能成功移动3个盘子,以此类推,最终让第2个和尚戒色能成功移动63个盘子时,戒懒就能完成所有盘子的移动了。 总结来说,递归分为"递"和"归"。递就是传递,就是将一个规模较大问题传递给稍小的问题(除了规模稍小,其他都相似,也就是需要保证解决大问题的方法和解决小问题的方法是同一个方法,才能使用函数调用它自身。),稍小问题传递给更小问题,直到不能再小,那么这时候函数就得到一个最终的值,这个值是很容易知道(最小问题(断奶小和尚)的解决方法)。这时候就执行"归",函数带着那个最终的值按顺序逐级返回,直到返回问题本身时,就终止

相关主题