N15数组字符函数及数组习题.ppt

  1. 1、本文档共31页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
N15数组字符函数及数组习题

前提:数据已按一定规律(升或降序)排列好。 思路:先检索正当中的一个数据是否所需,如不是,判断要找的数据在哪一边,缩小范围后再按同样方法继续检索,直到找到或找遍。 算法:设要找的数为x,n个数据已排好序存放在数组a中。 a、设low=0,high=n-1 mid=(low+high)/2 b、if (x= =a[mid]) 找到了; c、else if (xa[mid]) 说明x在右边,让low=mid+1; else 说明x在左边,让high=mid-1。 重复b和c两步操作, 直到x=mid(找到)或lowhigh(找遍了)为止。 课堂练习 1 输入3个字符串,要求找出其中最长者输出。 2 输入10个数,要求找出其中最大者输出。 main() { int a[5]={6,12,18,42,44}; int low=0,mid,high=4,x; printf(请输入要查找的数 x=); scanf(%d,x); do { mid=(low+high)/2; if (x==a[mid]) { printf(找到了!是第%d号元素。\n,mid);break; } else if(xa[mid]) low=mid+1; else high=mid-1; } while (low=high); if (lowhigh) printf(没找到!\n); } main() { int a[5]={6,12,18,42,44}; int low=0,mid,high=4,x,find=0; printf(请输入要查找的数 x=); scanf(%d,x); while (!find low=high) { mid=(low+high)/2; if (x==a[mid]) { find=1;break; } else if(xa[mid]) low=mid+1; else high=mid-1; } if( find==1) printf(找到了!是第%d号元素。\n,mid); else printf(没找到!\n); } 第一种情况:矩阵不是方阵m×n。 3 7 12 6 10 4 1 8 5 2 0 9 b[1][0] b[1][2] 8 1 4 10 6 12 7 3 9 0 2 5 a[0][1] a[2][1] 算法:for ( i=0 ; i3 ; i++ ) for (j=0 ; j4 ; j++) b[j][i]=a[i][j]; 例5 将一个矩阵进行转置(即原来的行变为列) 3 7 12 6 10 4 1 8 5 2 0 9 8 1 4 10 6 12 7 3 9 0 2 5 #includestdio.h main( ) { int a[3][4], b[4][3] , i , j ; for ( i=0 ; i3 ; i++ ) for ( j=0 ; j4 ; j++ ) scanf(“%d”, a[i][j] ) ; for ( i=0 ; i3 ; i++ ) for (j=0 ; j4 ; j++) b[j][i]=a[i][j]; for ( i=0 ; i4 ; i++ ) { for ( j=0 ; j3 ; j++ ) printf(“%5d”, b[i][j] ) ; printf(“\n”); } } a[0][1] b[1][0] a[2][1] b[1][2] 输入数组a 进行矩阵转置 输出数组b 第二种情况:矩阵是方阵n×n。 10

您可能关注的文档

文档评论(0)

173****7830 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档