下列程序的功能是:将一个正整数序列{K1, K2,…, K9}重新排列成一个新的序列。在新序列中,比K1小的数都在K1的前面(左面),比K1大的数都在K1的后面(右面)。要求编写函数jsValue()实现以上功能,最后调用函数writeDat(),将新序列输出到文件out.dat中。说明:程序中已给出了10个序列,每个序列中有9个正整数,并存入数组a[10][9] 中,分别求出这10个新序列。例如:序列{6, 8, 9, 1, 2, 5, 4, 7, 3}重排后为{3, 4, 5, 2, 1, 6, 8, 9, 7}。部分源程序已给出。请勿改动主函数main() 和写函数writeDat() 的内容。#includevoid jsValue(int a[10][9]){ } void main(){ int a[10][9]={{6,8,9,1,2,5,4,7,3} {3,5,8,9,1,2,6,4,7} {8,2,1,9,3,5,4,6,7} {3,5,1,2,9,8,6,7,4} {4,7,8,9,1,2,5,3,6} {4,7,3,5,1,2,6,8,9} {9,1,3,5,8,6,2,4,7} {2,6,1,9,8,3,5,7,4} {5,3,7,9,1,8,2,6,4} {7,1,3,2,5,8,9,4,6} }; int i,j; jsValue(a); for(i=0;i<10;i++){ for(j=0;j<9;j++) { printf("%d",a[i][j]); if(j<=7) printf(","); } printf("\n");}writeDat(a);}void writeDat(int a[10][9]){ FILE *fp; int i,j; fp=fopen("out.dat","w"); for(i=0;i<10;i++){ for(j=0;j<9;j++){ fprintf(fp,"%d",a[i][j]); if(j<=7) fprintf(fp,","); } fprintf(fp,"\n");} fclose(fp);}
A、第5行:x <y 第8行:x="y;" 第9行:y="z;<br/"> B、第5行:x>y 第8行:x=y; 第9行:y=z;
C、第5行:x <y 第8行: y="z;" 第9行:x="y;<br/"> D、第5行:x>y 第8行: y=z; 第9行:x=y;
B、第7行j++ 第8行a[i]>=a[j]
C、第7行j++ 第8行a[i]>a[j]
D、第7行j=j+1 第8行a[i]>=a[j]
Random Linear Search(A,x) //数组A[1..n],待查找对象x
1.Random Permute Array(A)
2.Linear Search(A,x)
假设A中有k(1≤k≤n)个元素等于x,试分析算法在调用Linear Search(A,x)时,执行循环的次数的期望值.
B.霍夫曼编码不具有检错和纠错能力
C.霍夫曼编码结果不唯一,所以其最佳码长也不唯一
D.霍夫曼编码是可变长度编码
为了保护您的账号安全,请在“简答题”公众号进行验证,点击“官网服务”-“账号验证”后输入验证码“”完成验证,验证成功后方可继续查看答案!