C第7章函数教程.ppt

  1. 1、本文档共53页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
说明 C编译系统对递归函数的自调用次数没有限制 由上面的图可以看出,这两种递归都是无终止的自身调用。程序中出现这种无终止的递归调用是不可以的,因为每调用函数一次,在内存堆栈区分配空间,用于存放函数变量、返回值等信息,所以递归次数过多,可能引起堆栈溢出 而只应出现有限次数的、有终止的递归调用,这可以用if语句来控制,只有在某一个条件成立时才继续执行递归调用。 1 2 a 调用前 1 2 a x 调用 2 1 a x 交换 2 1 a 返回 #include stdio.h void swap2(int x[ ]) { int z; z=x[0]; x[0]=x[1]; x[1]=z; } main() { int a[2]={1,2}; swap2(a); printf(a[0]=%d\na[1]=%d\n,a[0],a[1]); } 数组名作参数: 地址传递 例 数组元素与数组名 作函数参数比较 例8.13 数组排序----简单选择排序 #include stdio.h void selectsort( int array[], int n) { int i,j,k,t; for(i=0;in-1;i++) { k=i; for(j=i+1;jn;j++) if(array[j]array[k]) k=j; if(k!=i) { t=array[i]; array[i]=array[k]; array[k]=t; } } } main() { int a[10],i; for(i=0;i10;i++) scanf(%d,a[i]); selectsort(a,10); for(i=0;i10;i++) printf(%5d,a[i]); printf(\n); } 0 1 2 3 4 5 6 7 8 9 a 49 68 57 32 9 99 27 13 76 88 array k j j j k j k j j j j j 9 49 i=0 0 1 2 3 4 5 6 7 8 9 a 49 68 57 32 9 99 27 13 76 88 array k j j k j j j j j j 9 49 i=1 k k k 13 68 例8.13 数组排序----简单选择排序 #include stdio.h void sort( int array[], int n) { int i,j,k,t; for(i=0;in-1;i++) { k=i; for(j=i+1;jn;j++) if(array[j]array[k]) k=j; if(k!=i) { t=array[i]; array[i]=array[k]; array[k]=t; } } } main() { int a[10],i; for(i=0;i10;i++) scanf(%d,a[i]); sort(a,10); for(i=0;i10;i++) printf(%5d,a[i]); printf(\n); } 0 1 2 3 4 5 6 7 8 9 a 49 68 57 32 9 99 27 13 99 88 88 99 array 9 49 i=8 13 76 27 32 57 49 49 68 k j k 例8.13 数组排序----简单选择排序 #include stdio.h void sort( int array[], int n) { int i,j,k,t; for(i=0;in-1;i++) { k=i; for(j=i+1;jn;j++) if(array[j]array[k]) k=j; if(k!=i) { t=array[i]; array[i]=array[k]; array[k]=t; } } } main() { int a[10],i; for(i=0;i10;i++) scanf(%d,a[i]); sort(a,10); for(i=0;i10;i++) printf(%5d,a[i]); printf(\n);} 例8.14 求二维数组中最大元素值 j 1   3  5  7 2  4  6  8 15 17 34 12 i max=7 j 1  3  5  7 2  4  6  8 15 17

文档评论(0)

1112111 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档