首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读下列程序说明和C代码,将应填入(n)处的字句写在对应栏内。 【说明】 下面的程序功能的功能是以行为单位对字符串按下面的条件进行排序。排序条件为:从字符串中间一分为二,右边部分按字符的ASCII值降序排序,排序后左边部分与右边部分进行交换。如果原字
阅读下列程序说明和C代码,将应填入(n)处的字句写在对应栏内。 【说明】 下面的程序功能的功能是以行为单位对字符串按下面的条件进行排序。排序条件为:从字符串中间一分为二,右边部分按字符的ASCII值降序排序,排序后左边部分与右边部分进行交换。如果原字
admin
2009-02-15
35
问题
阅读下列程序说明和C代码,将应填入(n)处的字句写在对应栏内。
【说明】
下面的程序功能的功能是以行为单位对字符串按下面的条件进行排序。排序条件为:从字符串中间一分为二,右边部分按字符的ASCII值降序排序,排序后左边部分与右边部分进行交换。如果原字符串长度为奇数,则最中间的字符不参加排序,字符仍放在原位置上
例如:位置:0 1 2 3 4 5 6 7
源字符串:h g f e a b c d
则处理后字符串:d c b a h g f e
函数ReadDat()实现从文件in.dat中读取数据(每行字符串长度均小于80),函数WriteDat()把结果dat输出到文件out.dat中。
#include<stdio.h>
#include<siring.h>
#include<conio.h>
char dat[20] [80];
void jsSort()
{
int i,j,k,strl;
char ch;
for(i=0;i<20;i++)
strl=strlen(date
);
for(j=(1);j<strl;j++) /*对后半部分的字符串进行排序*/
for(k=j+1;k<strl;k++)
if( (2) )
{
ch=dat
[j];
dot
[j]=dat
[k];
dat
[k]=ch;
}
for(j=0; (3) j++) /*前后两部分进行交换*/
{
ch = date
[j];
dote
[j] = date
[(strl+1)/2+j];
dat
[(strl+1)/2+j]=ch;
}
}
}
void main()
{
reodDat();
isSort();
writeDot();
}
readDat ()
{
FILE * in;
int i=0;
char * p;
(4);
while(i<20 && fgets(dat
,80,in)!=NULL)
{
p = strchr(date
,"\n");
if(p) *p=0;
i++;
}
fclose (in);
}
writeDat()
{
FILE * out;
int i;
clrscr ();
out = fopen("out. dat" ,"W");
for(i=0;i<20;i++)
{
printf("%s\n",dar
);
printf ((5));
}
fclose (out);
}
选项
答案
(1)(strl+1)/2 (2)dat[i][j]<dat[i][k] (3)j<strl/2 (4)in=fopen("in. dat","r") (5)out,"% s\n",dat[i]
解析
程序的思路是:先调用函数ReadDat()从文件in.dat中读取20行数据存放到字符中数组dat中,然后调用函数jsSort()对字符串数组dar按照排序规则进行排序,排序后的结果仍按行重新存入字符串数组dat中,最后调用函数WriteDat()把结果dat输出到文件out.dat中。
(1)、(2)空所在的两重循环是对一行字符串的后半部分按字符的 ASCII值降序排序,这是一个简单的冒泡排序。考虑到如果原字符串长度为奇数,则最中间的字符不参加排序,因此应从第(strl+1)/2个元素开始排序,这就是(1)空所填的内容。由于是按字符的ASCII值降序排序,因此当dat
[j]<dat
[k]时就要进行数据交换,这就是 (2)空所填的内容。
(3)空所在的循环是进行前后两部分数据交换,因此,结束条件应为strl/2,因此空(3)应填“j<strl/2”。
(4)空所在函数是读取数据函数。在读取数据前先要以只读方式打开数据文件in.dat,因此空(4)处应填写“in=fopen("in.dat","r")”。
(5)空所在函数是写入排序结果函数。在(5)空所在行是把dat
一行写入到out.dat中,应此(5)空处应填写“out,"%"s\n",dat
”。
转载请注明原文地址:https://jikaoti.com/ti/FTW7FFFM
本试题收录于:
程序员下午应用技术考试题库软考初级分类
0
程序员下午应用技术考试
软考初级
相关试题推荐
描述事物的数据有绝对数据和相对数据之分。大气中氧气的含量属于相对数据,常用______形式表示。
某学生要进行数据结构、操作系统和计算机组成原理三门课的考试。已知数据结构成绩是85分、操作系统成绩是87分,希望总分达到240分,需要求出计算机组成原理成绩应考的分数。此类问题可以使用Excel中的(53)功能来解决。
在Excel中,绝对地址在被复制或移动到其他单元格时,其单元格地址______。
假设“EXAM.DOC”文件夹存储在“EXAM1”文件夹中,“EXAM1”文件夹存储在“EXAM2”文件夹中,“EXAM2”文件夹存储在F盘的根文件夹中,当前文件夹为“EXAM1”。那么,正确描述“EXAM.DOC”文件的绝对路径表示为(37)。
________________是按照科学的城市发展理念,利用新一代信息技术,通过人、物、城市功能系统之间的无缝连接与协同联动,实现自感知、自适应、自优化,形成安全、便捷、高效、绿色的城市形态。
在Word2010中,()快捷键可以选定当前文档中的全部内容。
Windows系统的控制面板不包括__________功能。
计算机使用一段时间后发现,系统启动时间变长,系统响应迟钝,应用程序运行缓慢,为此,需要进行系统优化。系统优化工作不包括___________。
该公司用一个C类地址块202.119.110.0/24组网,将下表中的(1)~(6)处空缺的主机地址或子网掩码填写在答题纸的相应位置。可以采用(10)方法防止IP地址被盗用。(10)A.IP地址与子网掩码进行绑定B.IP地址与MAC地址进行
随机试题
从行政组织职能作用的性质来看,政府职能由保卫性、统治性职能为主向___________、___________职能为主的方向转变。
改变病情抗风湿药治疗类风湿关节炎的作用包括
鉴别囊肿与实性肿瘤最可靠的依据是
下列哪个因素可导致鸡脑软化
新生儿病理性黄疸的特点不包括()
正常产程进展的标志是()。
下列关于Partnering模式的讨论中,不正确的是( )。
汇总记账凭证账务处理程序的优点是()。
下列叙述中正确的是
Simon:IworknotbecauseIlikeitbutthatIhaveto,soIoftencounttheminutesuntilstoppingworkorholidays.Howeve
最新回复
(
0
)