首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知数据文件IN58.DAT中存有300个4位数,并已调用读函数readDat()把这些数存入数组a中,请编制一函数JsValue(),其功能是:求出这些4位数是素数的个数cnt,再把所有满足此条件的4位数依次存入数组b中,然后对数组b的4位数按从小到大的
已知数据文件IN58.DAT中存有300个4位数,并已调用读函数readDat()把这些数存入数组a中,请编制一函数JsValue(),其功能是:求出这些4位数是素数的个数cnt,再把所有满足此条件的4位数依次存入数组b中,然后对数组b的4位数按从小到大的
admin
2009-02-15
82
问题
已知数据文件IN58.DAT中存有300个4位数,并已调用读函数readDat()把这些数存入数组a中,请编制一函数JsValue(),其功能是:求出这些4位数是素数的个数cnt,再把所有满足此条件的4位数依次存入数组b中,然后对数组b的4位数按从小到大的顺序进行排序,最后调用函数writeDat()把数组b中的数输出到OUT58.DAT文件中。
例如:5591是素数,则该数满足条件,存入数组b中,且个数cnt=cnt+1。
9812是非素数,则该数不满足条件,忽略。
注意:部分源程序己给出。
程序中已定义数组:a[300],b[300],已定义变量:cnt。
请勿改动主函数main()、读函数readDat()和写函数writeDat()的内容。
试题程序:
#include<stdio.h>
int a[300],b[300],cnt=0;
int isP(int m)
{
int i;
for(i=2;i<m;i++)
if(m%i==0) return 0;
return 1;
}
jsValue )
{
}
main ( )
{
int i;
readDat ( );
jsValue();
writeDat();
printf("cnt=%d\n",cnt);
for(i=0;i<cnt;i++)
printf( "b [%d] =%d\n ",i,b
);
}
readDat ( )
{
FILE *fp;
int i;
fp=fopen("IN58.DAT","r");
for(i=0;i<300;i++)
fscanf(fp,"%d,",&a
);
fclose(fp);
}
writeDat()
{
FILE *fp;
int i;
fp=fopen("OUT58.DAT","w");
fprintf(fp,"%d\n",cnt);
for(i=0;i<cnt;i++)
fprintf(fp, "%d\n",b
);
fclose(fp);
}
选项
答案
jsValue ( ) { int i, j ,value; for (i=0; i<300; i++) if(isP(a[i])) /*如果该数为素数,则将该数存入数组b中*/ { b[cnt]=a[i]; cnt++; /*并统计满足条件的数的个数*/ } for (i=0; i<cnt-1; i++) /*对数组b的4位数按从小到大的顺序进行排序*/ for (j=i+1; j<cnt; j++) if(b[i]>b[j]) { value=b[i]; b[i]=b[j]; b [j]=value; } }
解析
本题考查的知识点如下:
(1)循环的嵌套。
(2)数据的排序。
在本题中,已给出了判断素数的函数vold isP(int m),只需将数代入进行判断即可。将素数存入数组b,再对数组b中的数进行排序。排序采用“选择排序法”——第一次从第一个数据开始和所有后面的数据进行比较,与比它大(小)的数据交换位置,将数据中最大(小)的数交换到最前面。第二次从第二个数据开始与后面的数据进行比较,将本次比较中最大(小)的数据交换至第二个位置,直至最后一个数据。以此类推,则可完成题目的要求。
转载请注明原文地址:https://kaotiyun.com/show/7HfZ777K
本试题收录于:
三级信息管理技术题库NCRE全国计算机三级分类
0
三级信息管理技术
NCRE全国计算机三级
相关试题推荐
数据加密标准是最典型的()加密算法,它是由IBM公司提出,经过国际标准化组织认证的数据加密的国际标准。
IEEE802.11定义了无线局域网的两种工作模式,其中哪一种模式是点对点连接的网络,不需要无线接入点和有线网络的支持,用无线网卡连接的设备之间就可以直接通信()。
单台交换机是一台()工作、()堆叠的交换机。
综合布线采用()和相关连接硬件,进行模块化设计,因此所有通道都是通用的。
宽带城域网的可管理性不包括()。
某局域网的Internet接入拓扑结构图下图所示。由于用户在使用telnet登录网络设备或服务器时所使用的用户名和口令在网络中以明文传输,很容易被网络上的非法协议分析截获。因此需要定义一条规则号为110,禁止所有外网主机和内网主机进行远程登录的访问控制规则
运行OSPF协议的路由器每10s向它的各个接口发送Hello分组,接收到该分组的路由器就知道了邻居的存在。为了避免路由信息被重复发送,需要给路由信息包编号。假设每秒钟传一次路由信息,为确保路由信息包的编号在一年内不重复使用,则编号的最短长度应为()
邮件服务器安装设置完成后,除了可使用Web浏览器登录邮件服务器进行测试外,还可以使用()进行测试
在小型的并且不接入Internet的网络中,域名解析可以采用静态的方法,即由hosts文件完成这一工作,在每台计算机上的hosts文件中配置主机名和IP地址的转换关系;但在大型的网络中,域名解析通常采用动态的方法,完成动态名称解析的系统称()。
R1,R2是一个自治系统中采用RIP路由协议的两个相邻路由器,R1的路由表如下图(a)所示,如果R1收到R2发送的如下图(b)所示的(V,D)报文后,更新后RI的五个路由表项的距离值从上到下依次为0、4、4、3、2那么、a、b、c、d、e可能的
随机试题
下列哪项不是SLE淋巴结肿大的临床表现
检查脊柱的压痛的方法和临床意义正确的是
4周岁小儿的身长应为
在药品零售企业中,需要凭处方方可销售的特殊药品复方制剂除了()。
(2005年)pz波函数角度分布形状为()。
按时间分类,支付可分为()。
根据《个人外汇管理办法》的规定,个人外汇账户按账户性质可划分为()。
若商业银行核心资本距监管当局的要求相差较远,可以采取()的方式来提高资本充足率。
已知A是m×n矩阵,m<n证明:AAT是对称阵,并且AAT正定的充要条件是r(A)=m.
Onwhataspectofweatherforecastingdoestheconversationfocus?
最新回复
(
0
)