17-一维数组查找、排序.doc

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

一维数组应用(查找、排序) 例一:查找数组A中是否有等于NUM的这个数,有,则返回这个数在数组中的位置;没有,则返回0。(假设A中有N个互异的整数) 程序: CONST N = 10; VAR A:= ARRAY [ 1..N ] OF INTEGER ; P,X : INTEGER; BEGIN 给数组A赋初值; WRITELN(‘PLEASE INPUT X : ’); READLN(X); P := N; WHILE ( A[ P ] X)AND ( P 0 ) DO P:= P - 1; IF A[ P ] 〈 〉 X THEN P:=0 ; WRITELN(P); END. 改进:多定义1个A [ 0 ] ,即VAR A:= ARRAY [ 0..N ] OF INTEGER ; 然后: P:=N; A[ 0 ] := X ; WHILE A[ P ] 〈 〉 X DO P := P – 1 ; 其中A[ 0 ] 称为哨兵,减少了比较次数。 例二:在一个已经排好序的数组中查找某一个数 。有则返回这个数在数组中的位置,没有则返回0。(假设A中有N个互异的整数) 分析:可以用例一方法,但效率低,下面用“二分法” 程序:CONST N = 10; VAR A:ARRAY [ 1 ..N ] OF INTEGER ; I,J,K,P,X :INTEGER ; FIND:BOOLEAN ; BEGIN WRITELN(‘INPUT A ORDERED ARRAY :’); FOR I := 1 TO N DO READ (A[ I ]) ; READLN; WRITE(‘INPUT X: ’); READLN(X); I:=1 ;J:= N ;FIND := FALSE ; WHILE (NOT FIND )AND (I J ) DO BEGIN K:=( I + J ) DIV 2 ; IF A[ K ] := X THEN FIND := TRUE ELSE IF A[ K ] X THEN J:= K – 1 ELSE I:= K + 1 ; END; IF FIND THEN P:= K ELSE P:= 0 ; WRITELN(P); END. 例三:有N个数存放于数组A中,将其按照从小到大的顺序重新排列。 选择排序法:用“打擂台”法将最小的1个数找出来放在数组的最前面。 然后在剩下的N-1个数中重复做上面的操作……….., 一共要N – 1 趟。 CONST N = 10 ; VAR A:ARRAY [ 1..N ] OF INTEGER ; I,J,P,T:INTEGER ; BEGIN FOR I:= 1 TO N DO READ(A[ I ]); READLN; FOR I:= 1 TO

您可能关注的文档

文档评论(0)

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

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

版权声明书
用户编号:6111134150000003

1亿VIP精品文档

相关文档