程序设计竞赛练习题.doc_第1页
程序设计竞赛练习题.doc_第2页
程序设计竞赛练习题.doc_第3页
程序设计竞赛练习题.doc_第4页
程序设计竞赛练习题.doc_第5页
已阅读5页,还剩62页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

徐州师范大学 程序设计竞赛练习题2012-2-9酆格斐练习1 1000A+B ProblemDescriptionCalculate a + bInputTwo integer a,b (0 a,b 10)OutputOutput a + b Sample Input1 2Sample Output3练习2 2713肿瘤面积Time Limit:1000MS Memory Limit:65536KDescription在一个正方形的灰度图片上,肿瘤是一块矩形的区域,肿瘤的边缘所在的像素点在图片中用0表示。其它肿瘤内和肿瘤外的点都用255表示。现在要求你编写一个程序,计算肿瘤内部的像素点的个数(不包括肿瘤边缘上的点)。已知肿瘤的边缘平行于图像的边缘。Input只有一个测试样例。第一行有一个整数n,表示正方形图像的边长。其后n行每行有n个整数,取值为0或255。整数之间用一个空格隔开。已知n不大于1000。Output输出一行,该行包含一个整数,为要求的肿瘤内的像素点的个数。Sample Input5255 255 255 255 255255 0 0 0 255255 0 255 0 255255 0 0 0 255255 255 255 255 255Sample Output1Hint如果使用静态数组来表示图片数据,需要将该数组定义成全局变量。练习3 2714求平均年龄Time Limit:1000MS Memory Limit:65536KDescription班上有学生若干名,给出每名学生的年龄(整数),求班上所有学生的平均年龄,保留到小数点后两位。Input第一行有一个整数n(1= n = 100),表示学生的人数。其后n行每行有1个整数,取值为15到25。Output输出一行,该行包含一个浮点数,为要求的平均年龄,保留到小数点后两位。Sample Input21817Sample Output17.50Hint要输出浮点数、双精度数小数点后2位数字,可以用下面这种形式: printf(%.2f, num); 练习4 2796数字求和Time Limit:3000MS Memory Limit:65536KDescription给定一个正整数a,以及另外的5个正整数,问题是:这5个整数中,小于a的整数的和是多少?Input输入一行,只包括6个小于100的正整数,其中第一个正整数就是a。Output输出一行,给出一个正整数,是5个数中小于a的数的和。Sample Input10 1 2 3 4 11Sample Output10练习5 2807两倍Time Limit:1000MS Memory Limit:65536KDescription给定2到15个不同的正整数,你的任务是计算这些数里面有多少个数对满足:数对中一个数是另一个数的两倍。 比如给定1 4 3 2 9 7 18 22,得到的答案是3,因为2是1的两倍,4是2个两倍,18是9的两倍。 Input输入包括多组测试数据。每组数据包括一行,给出2到15个两两不同且小于100的正整数。每一行最后一个数是0,表示这一行的结束后,这个数不属于那2到15个给定的正整数。输入的最后一行只包括一个整数-1,这行表示输入数据的结束,不用进行处理。Output对每组输入数据,输出一行,给出有多少个数对满足其中一个数是另一个数的两倍。Sample Input1 4 3 2 9 7 18 22 02 4 8 10 07 5 11 13 1 3 0-1Sample Output320练习6 2750鸡兔同笼Time Limit:1000MS Memory Limit:65536KDescription一个笼子里面关了鸡和兔子(鸡有2只脚,兔子有4只脚,没有例外)。已经知道了笼子里面脚的总数a,问笼子里面至少有多少只动物,至多有多少只动物Input第1行是测试数据的组数n,后面跟着n行输入。每组测试数据占1行,每行一个正整数a (a 32768)Output输出包含n行,每行对应一个输入,包含两个正整数,第一个是最少的动物数,第二个是最多的动物数,两个正整数用一个空格分开 如果没有满足要求的答案,则输出两个0。 Sample Input2320Sample Output0 05 10练习7 1657棋盘上的距离Time Limit:1000MS Memory Limit:10000KDescription国际象棋的棋盘是黑白相间的8 * 8的方格,棋子放在格子中间。如下图所示: 王、后、车、象的走子规则如下: 王:横、直、斜都可以走,但每步限走一格。 后:横、直、斜都可以走,每步格数不受限制。 车:横、竖均可以走,不能斜走,格数不限。 象:只能斜走,格数不限。写一个程序,给定起始位置和目标位置,计算王、后、车、象从起始位置走到目标位置所需的最少步数。 Input第一行是测试数据的组数t(0 = t = 20)。以下每行是一组测试数据,每组包括棋盘上的两个位置,第一个是起始位置,第二个是目标位置。位置用字母-数字的形式表示,字母从a到h,数字从1到8。 Output对输入的每组测试数据,输出王、后、车、象所需的最少步数。如果无法到达,就输出Inf.Sample Input2a1 c3f5 f8Sample Output2 1 2 13 1 1 Inf练习8 2808校门外的树Time Limit:1000MS Memory Limit:65536KDescription某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米。我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置;数轴上的每个整数点,即0,1,2,L,都种有一棵树。 马路上有一些区域要用来建地铁,这些区域用它们在数轴上的起始点和终止点表示。已知任一区域的起始点和终止点的坐标都是整数,区域之间可能有重合的部分。现在要把这些区域中的树(包括区域端点处的两棵树)移走。你的任务是计算将这些树都移走后,马路上还有多少棵树。 Input输入的第一行有两个整数L(1 = L = 10000)和 M(1 = M = 100),L代表马路的长度,M代表区域的数目,L和M之间用一个空格隔开。接下来的M行每行包含两个不同的整数,用一个空格隔开,表示一个区域的起始点和终止点的坐标。Output输出包括一行,这一行只包含一个整数,表示马路上剩余的树的数目。Sample Input500 3150 300100 200470 471Sample Output298练习9 2801填词Time Limit:1000MS Memory Limit:65536KDescriptionAlex喜欢填词游戏。填词是游戏是一个非常简单的游戏。填词游戏包括一个N * M大小的矩形方格盘和P个单词。玩家需要把每个方格中填上一个字母使得每个单词都能在方格盘上找到。每个单词都能找到要满足下面的条件: 每个方格都不能同时属于超过一个的单词。一个长为k的单词一定要占据k个方格。单词在方格盘中出现的方向只能是竖直的或者水平的。 你的任务是首先在方格盘上找到所有的单词,当然在棋盘上可能有些方格没有被单词占据。然后把这些没有用的方格找出来,把这些方格上的字母按照字典序组成一个“神秘单词”。 如果你还不了解规则,我们可以具一个例子,比如在下图中寻找单词BEG和GEE。 Input输入的第一行包括三个整数N,M和P (2 = M, N = 10, 0 = P =100)。接下来的N行,每行包括M个字符,来表示方格盘。接下来P行给出需要在方格盘中找到的单词。 输入保证填词游戏至少有一组答案。 输入中给出的字母都是大写字母。 Output输出“神秘单词”,注意“神秘单词”中的字母要按照字典序给出。Sample Input3 3 2EBGGEEEGEBEGGEESample OutputEEG练习10 1017装箱问题Time Limit:1000MS Memory Limit:10000KDescription一个工厂制造的产品形状都是长方体,它们的高度都是h,长和宽都相等,一共有六个型号,他们的长宽分别为1*1, 2*2, 3*3, 4*4, 5*5, 6*6。这些产品通常使用一个 6*6*h 的长方体包裹包装然后邮寄给客户。因为邮费很贵,所以工厂要想方设法的减小每个订单运送时的包裹数量。他们很需要有一个好的程序帮他们解决这个问题从而节省费用。现在这个程序由你来设计。Input输入文件包括几行,每一行代表一个订单。每个订单里的一行包括六个整数,中间用空格隔开,分别为1*1至6*6这六种产品的数量。输入文件将以6个0组成的一行结尾。Output除了输入的最后一行6个0以外,输入文件里每一行对应着输出文件的一行,每一行输出一个整数代表对应的订单所需的最小包裹数。Sample Input0 0 4 0 0 1 7 5 1 0 0 0 0 0 0 0 0 0 Sample Output2 1 练习11 2677肿瘤检测Time Limit:1000MS Memory Limit:65536KDescription一张CT扫描的灰度图像可以用一个N*N(0N100)的矩阵描述,矩阵上的每个点对应一个灰度值(整数),其取值范围是0-255。我们假设给定的图像中有且只有一个肿瘤。在图上监测肿瘤的方法如下:如果某个点对应的灰度值小于等于50,则这个点在肿瘤上,否则不在肿瘤上。我们把在肿瘤上的点的数目加起来,就得到了肿瘤在图上的面积。任何在肿瘤上的点,如果它是图像的边界或者它的上下左右四个相邻点中至少有一个是非肿瘤上的点,则该点称为肿瘤的边界点。肿瘤的边界点的个数称为肿瘤的周长。现在给定一个图像,要求计算其中的肿瘤的面积和周长。Input输入第一行包含一个正整数N(0N100),表示图像的大小;接下来N行,每行包含图像的一行。图像的一行用N个整数表示(所有整数大于等于0,小于等于255),两个整数之间用一个空格隔开。Output输出只有一行,该行包含两个正整数,分别为给定图像中肿瘤的面积和周长,用一个空格分开。Sample Input699 99 99 99 99 9999 99 99 50 99 9999 99 49 49 50 5199 50 20 25 52 9940 50 99 99 99 9999 99 99 99 99 99Sample Output9 8练习12 2800垂直直方图Time Limit:1000MS Memory Limit:65536KDescription输入4行全部由大写字母组成的文本,输出一个垂直直方图,给出每个字符出现的次数。注意:只用输出字符的出现次数,不用输出空白字符,数字或者标点符号的输出次数。Input输入包括4行由大写字母组成的文本,每行上字符的数目不超过80个。Output输出包括若干行。其中最后一行给出26个大写英文字母,这些字母之间用空格隔开。前面的几行包括空格和星号,每个字母出现几次,就在这个字母的上方输出一个星号。注意:输出的第一行不能是空行。Sample InputTHE QUICK BROWN FOX JUMPED OVER THE LAZY DOG.THIS IS AN EXAMPLE TO TEST FOR YOURHISTOGRAM PROGRAM.HELLO!Sample Output * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *A B C D E F G H I J K L M N O P Q R S T U V W X Y Z练习13 1338Ugly NumbersTime Limit: 1000MSMemory Limit: 10000KDescriptionUgly numbers are numbers whose only prime factors are 2, 3 or 5. The sequence 1, 2, 3, 4, 5, 6, 8, 9, 10, 12, . shows the first 10 ugly numbers. By convention, 1 is included. Given the integer n,write a program to find and print the nth ugly number. InputEach line of the input contains a postisive integer n (n = 1500).Input is terminated by a line with n=0.OutputFor each line, output the nth ugly number .:Dont deal with the line with n=0.Sample Input1290Sample Output1210练习14 2818密码Time Limit:1000MS Memory Limit:65536KDescriptionBob 和 Alice 开始使用一种全新的编码系统。它是一种基于一组私有钥匙的。他们选择了n个不同的数a1 , . . .,an, 它们都大于0小于等于n。 机密过程如下:待加密的信息放置在这组加密钥匙下,信息中的字符和密钥中的数字一一对应起来。信息中位于i位置的字母将被写到加密信息的第ai个位置, ai 是位于i位置的密钥。加密信息如此反复加密,一共加密 k 次。 信息长度小于等于n。如果信息比 n 短, 后面的位置用空格填补直到信息长度为n。 请你帮助 Alice 和 Bob 写一个程序,读入密钥,然后读入加密次数 k 和要加密的信息,按加密规则将信息加密。 Input输入包括几块。每块第一行有一个数字n, 0 n = 200. 接下来的行包含n个不同的数字。数字都是大于0小于等于n的。下面每行包含一个k和一个信息字符串,它们之间用空格格开。每行以换行符结束,换行符不是要加密的信息。每个块的最后一行只有一个0。 最后一个块后有一行,该行只有一个0。 Output输出有多个块,每个块对应一个输入块。每个块包含输入中的信息经过加密后的字符串,顺序与输入顺序相同。所有加密后的字符串的长度都是 n。 每一个块后有一个空行。 Sample Input104 5 3 7 2 8 1 6 10 91 Hello Bob1995 CERC00Sample OutputBolHeol bC RCE练习15数字平方和求所有满足如下条件的三位数:它除以11得的商等于它各位数字的平方和。例如550,除以11商为50,52+52+02=50#include int main(int argc, char *argv)int i, j, n, s;for(i=100;i=1, n=1中由小到大排列的前70项数。练习22 1047,2952循环数Time Limit:1000MS Memory Limit:10000KDescriptionn 位的一个整数是循环数(cyclic)的条件是:当用一个 1 到 n 之间的整数去乘它时, 会得到一个将原来的数首尾相接循环移动若干数字再在某处断开而得到的数字。也就是说,如果把原来的数字和新的数字都首尾相接,他们得到的环是相同的。只是两个数的起始数字不一定相同。例如,数字 142857 是循环数,因为: 142857 *1 = 142857 142857 *2 = 285714 142857 *3 = 428571 142857 *4 = 571428 142857 *5 = 714285 142857 *6 = 857142 Input写一个程序确定给定的数是否是循环数。输入包括多个长度为 2 位到 60 位的整数。(注意,先导的0也是合理的输入不应该被忽略,例如 01是 2 位数,1 是 1 位数。)Output对于每一个输入的整数,输出一行表明它是否是循环数。Sample Input142857142856142858010588235294117647Sample Output142857 is cyclic142856 is not cyclic142858 is not cyclic01 is not cyclic0588235294117647 is cyclic练习23 1936, 2976All in allTime Limit:1000MS Memory Limit:30000K Description给定两个字符串s和t,请判断s是否是t的子序列。即从t中删除一些字符,将剩余的字符连接起来,即可获得s。Input包括若干个测试数据。每个测试数据由两个ASCII码的数字和字母串s和t组成,s和t的长度不超过100000。Output对每个测试数据,如果s是t的子序列则输出“Yes”,否则输出“No”。Sample Inputsequence subsequenceperson compressionVERDI vivaVittorioEmanueleReDiItaliacaseDoesMatter CaseDoesMatterSample OutputYesNoYesNo练习24 2744子串Time Limit:1000MS Memory Limit:65536KDescription现在有一些由英文字符组成的大小写敏感的字符串,你的任务是找到一个最长的字符串x,使得对于已经给出的字符串中的任意一个y,x或者是y的子串,或者x中的字符反序之后得到的新字符串是y的子串。Input输入的第一行是一个整数t (1 = t = 10),t表示测试数据的数目。对于每一组测试数据,第一行是一个整数n (1 = n = 100),表示已经给出n个字符串。接下来n行,每行给出一个长度在1和100之间的字符串。Output对于每一组测试数据,输出一行,给出题目中要求的字符串x的长度。Sample Input23ABCDBCDFFBRCD2roseorchidSample Output22练习25 2820古代密码Time Limit:1000MS Memory Limit:65536KDescription古罗马帝王有一个包括各种部门的强大政府组织。其中有一个部门就是保密服务部门。为了保险起见,在省与省之间传递的重要文件中的大写字母是加密的。当时最流行的加密方法是替换和重新排列。 替换方法是将所有出现的字符替换成其它的字符。有些字符会碰巧替换成它自己。例如:替换规则可以是将A 到 Y替换成它的下一个字符,将Z替换成 A,如果原词是 VICTORIOUS 则它变成 WJDUPSJPVT。 排列方法改变原来单词中字母的顺序。例如:将顺序 应用到 VICTORIOUS 上,则得到IVOTCIRSUO。 人们很快意识到单独应用替换方法或排列方法,加密是很不保险的。但是如果结合这两种方法,在当时就可以得到非常可靠的加密方法。所以,很多重要信息先使用替换方法加密,再将加密的结果用排列的方法加密。用两中方法结合就可以将VICTORIOUS 加密成JWPUDJSTVP。 考古学家最近在一个石台上发现了一些信息。初看起来它们毫无意义,所以有人设想它们可能是用替换和排列的方法被加密了。人们试着解读了石台上的密码,现在他们想检查解读的是否正确。他们需要一个计算机程序来验证她,你的任务就是写这个验证程序。 Input输入有两行。第一行是石台上的文字。文字中没有空格,并且只有大写英文字母。第二行是被解读出来的加密前的文字。第二行也是由大写英文字母构成的。 两行字符数目的长度都不超过计划100。Output如果第二行经过某种加密方法后可以产生第一行的信息,输出 YES,否则输出NO。Sample InputJWPUDJSTVPVICTORIOUSSample OutputYES练习26 3630Phone ListTime Limit: 1000MSMemory Limit: 65536KDescriptionGiven a list of phone numbers, determine if it is consistent in the sense that no number is the prefix of another. Lets say the phone catalogue listed these numbers:Emergency 911 Alice 97 625 999 Bob 91 12 54 26In this case, its not possible to call Bob, because the central would direct your call to the emergency line as soon as you had dialled the first three digits of Bobs phone number. So this list would not be consistent.InputThe first line of input gives a single integer, 1 t 40, the number of test cases. Each test case starts with n, the number of phone numbers, on a separate line, 1 n 10000. Then follows n lines with one unique phone number on each line. A phone number is a sequence of at most ten digits. OutputFor each test case, output YES if the list is consistent, or NO otherwise.Sample Input2391197625999911254265113123401234401234598346Sample OutputNOYES练习27 2804or2503词典Time Limit:3000MS Memory Limit:65536KDescription你旅游到了一个国外的城市。那里的人们说的外国语言你不能理解。不过幸运的是,你有一本词典可以帮助你。Input首先输入一个词典,词典中包含不超过100000个词条,每个词条占据一行。每一个词条包括一个英文单词和一个外语单词,两个单词之间用一个空格隔开。而且在词典中不会有某个外语单词出现超过两次。词典之后是一个空行,然后给出一个由外语单词组成的文档,文档不超过100000行,而且每行只包括一个外语单词。输入中出现单词只包括小写字母,而且长度不会超过10。Output在输出中,你需要把输入文档翻译成英文,每行输出一个英文单词。如果某个外语单词不在词典中,就把这个单词翻译成“eh”。 Sample Inputdog ogdaycat atcaypig igpayfroot ootfrayloops oopslayatcayittenkayoopslaySample OutputcatehloopsHint输入比较大,推荐使用C语言的I / O函数。练习28 1002,2974487-3279Time Limit:2000MS Memory Limit:30000KDescription企业喜欢用容易被记住的电话号码。让电话号码容易被记住的一个办法是将它写成一个容易记住的单词或者短语。例如,你需要给滑铁卢大学打电话时,可以拨打TUT-GLOP。有时,只将电话号码中部分数字拼写成单词。当你晚上回到酒店,可以通过拨打310-GINO来向Ginos订一份pizza。让电话号码容易被记住的另一个办法是以一种好记的方式对号码的数字进行分组。通过拨打必胜客的“三个十”号码3-10-10-10,你可以从他们那里订pizza。电话号码的标准格式是七位十进制数,并在第三、第四位数字之间有一个连接符。电话拨号盘提供了从字母到数字的映射,映射关系如下:A, B, 和C 映射到 2 D, E, 和F 映射到 3 G, H, 和I 映射到 4 J, K, 和L 映射到 5 M, N, 和O 映射到 6 P, R, 和S 映射到 7 T, U, 和V 映射到 8 W, X, 和Y 映射到 9 Q和Z没有映射到任何数字,连字符不需要拨号,可以任意添加和删除。 TUT-GLOP的标准格式是888-4567,310-GINO的标准格式是310-4466,3-10-10-10的标准格式是310-1010。 如果两个号码有相同的标准格式,那么他们就是等同的(相同的拨号) 你的公司正在为本地的公司编写一个电话号码薄。作为质量控制的一部分,你想要检查是否有两个和多个公司拥有相同的电话号码。 Input输入的格式是,第一行是一个正整数,指定电话号码薄中号码的数量(最多100000)。余下的每行是一个电话号码。每个电话号码由数字,大写字母(除了Q和Z)以及连接符组成。每个电话号码中只会刚好有7个数字或者字母。Output对于每个出现重复的号码产生一行输出,输出是号码的标准格式紧跟一个空格然后是它的重复次数。如果存在多个重复的号码,则按照号码的字典升序输出。如果输入数据中没有重复的号码,输出一行: No duplicates.Sample Input124873279ITS-EASY888-45673-10-10-10888-GLOPTUT-GLOP967-11-11310-GINOF101010888-1200-4-8-7-3-2-7-9-487-3279Sample Output310-1010 2487-3279 4888-4567 3 练习29 1200Crazy SearchTime Limit:1000MS Memory Limit:65536KDescriptionMany people like to solve hard puzzles some of which may lead them to madness. One such puzzle could be finding a hidden prime number in a given text. Such number could be the number of different substrings of a given size that exist in the text. As you soon will discover, you really need the help of a computer and a good algorithm to solve such a puzzle. Your task is to write a program that given the size, N, of the substring, the number of different characters that may occur in the text, NC, and the text itself, determines the number of different substrings of size N that appear in the text. As an example, consider N=3, NC=4 and the text daababac. The different substrings of size 3 that can be found in this text are: daa; aab; aba; bab; bac. Therefore, the answer should be 5. InputThe first line of input consists of two numbers, N and NC, separated by exactly one space. This is followed by the text where the search takes place. You may assume that the maximum number of substrings formed by the possible set of characters does not exceed 16 Millions. OutputThe program should output just an integer corresponding to the number of different substrings of size N found in the given text. Sample Input3 4daababacSample Output5HintHuge input,scanf is recommended.练习30 2797最短前缀Time Limit:1000MS Memory Limit:65536KDescription一个字符串的前缀是从该字符串的第一个字符起始的一个子串。例如 carbon的字串是: c, ca, car, carb, carbo, 和 carbon。注意到这里我们不认为空串是字串, 但是每个非空串是它自身的字串. 我们现在希望能用前缀来缩略的表示单词。例如, carbohydrate 通常用carb来缩略表示. 现在给你一组单词, 要求你找到唯一标识每个单词的最短前缀 在下面的例子中,carbohydrate 能被缩略成carboh, 但是不能被缩略成carbo (或其余更短的前缀) 因为已经有一个单词用carbo开始 一个精确匹配会覆盖一个前缀匹配,例如,前缀car精确匹配单词car. 因此 car 是 car的缩略语是没有二义性的 , “car”不会被当成carriage或者任何在列表中以car开始的单词. Input输入包括至少2行,至多1000行. 每行包括一个以小写字母组成的单词,单词长度至少是1,至多是20.Output输出的行数与输入的行数相同。每行输出由相应行输入的单词开始,后面跟着一个空格接下来是相应单词的没有二义性的最短前缀标识符。Sample InputcarbohydratecartcarburetorcaramelcariboucarboniccartilagecarboncarriagecartoncarcarbonateSample Outputcarbohydrate carbohcart cartcarburetor carbucaramel caracaribou caricarbonic carbonicartilage carticarbon carboncarriage carrcarton cartocar carcarbonate carbona练习31求排序后的位置本题是一个排序算法的程序,对数组A中的n个元素,求出每个元素排序后应有的位置。#include #define MAX 100typedef struct stint key;int count;NODEMAX;void count_sort(NODE A, int n);int main(int argc, char *argv)int i, n;NODE A;printf(input array length n);scanf(%d, &n);printf(please input data n);for(i=0;in;i+)scanf(%d, &Ai.key);count_sort(A, n);for(i=0;in;i+)printf(A%d=%3d , i, Ai.key, Ai.count);return 0;void count_sort(NODE A, int n)int i, j;for(i=0;in;i+)_A_;for(i=0;in-1;i+)for(j=i+1;jn;j+)if(Ai.keyAj.key)_B_;else_C_;练习32下沉排序对R的n个元素R0,R1,Rn-1进行排序的程序,按从左到右的方向扫描,当Ri.keyRi+1.key时,让元素Ri+1逐步下沉到某个位置#include #include #define m 100typedef structint key;float inf;element;typedef element Listm;void bub_sort(List R, int n)int i, j;element extra;for(i=0;iRj+1.key)extra = Rj;Rj = Rj+1;Rj+1 = extra;_B_;int main(int argc, char *argv)int i, n;List list;printf(input array length n);scanf(%d, &n);printf(please input data n);for(i=0;in;i+)scanf(%d, &listi.key);bub_sort(list, n);for(i=0;in;i+)printf(%3d , listi.key);return 0;练习33动摇排序下面排序算法称为摇动排序,它是对冒泡排序的一种改进。数组r含n个元素r0,r1,r2,rn-1。从一端开始扫描,进行比较、交换,然后改变下一趟的扫描方向进行同样处理。#include #include #define m 100typedef structint key;float inf;element;typedef element listm;void shakesort(list r, int n)int i, t, l, h;element extr;l = 0;h = n - 1;_A_;dofor(i=l;i ri+1.key)e

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论