首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
对10个候选人进行选举,现有一个100条记录的选票文件IN84.DAT,其数据存放格式是每条记录的长度均为10位,第一位表示第一个人的选中情况,第二位表示第二个人的选中情况,依此类推。每一位候选人的记录内容均为字符0或1,1表示此人被选中,0表示此人未被选
对10个候选人进行选举,现有一个100条记录的选票文件IN84.DAT,其数据存放格式是每条记录的长度均为10位,第一位表示第一个人的选中情况,第二位表示第二个人的选中情况,依此类推。每一位候选人的记录内容均为字符0或1,1表示此人被选中,0表示此人未被选
admin
2010-01-09
32
问题
对10个候选人进行选举,现有一个100条记录的选票文件IN84.DAT,其数据存放格式是每条记录的长度均为10位,第一位表示第一个人的选中情况,第二位表示第二个人的选中情况,依此类推。每一位候选人的记录内容均为字符0或1,1表示此人被选中,0表示此人未被选十,若一张选票选中人数大于5个人时被认为无效的选票。给定函数ReadDat()的功能是把选票数据读入到字符串数组xx中。请编制函数CoutRs()来统计每个人的选票数并把得票数依次存入yy[0]到yy[9]中,最后调用函数WriteDat()把结果yy输出到文件 OUT84.DAT中。
注意:部分源程序已给出。
请勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。
试题程序:
#include<stdio.h>
char xx[100] [11];
int yy[10];
int ReadDat (void);
void WriteDat(void);
void CoutRs(void)
{
}
void main()
{
int i;
for(i=0;i<10;i++)
yy
=0;
if (ReadDat ())
{
printf ("数据文件IN84 .DAT不能打开! \n\007");
return;
}
CoutRs ();
WriteDat ();
}
int ReadDat (void)
{
FILE *fp;
int i;
char tt[13];
if ( (fp=fopen ("IN84 .DAT", "r") ) ==NULL) return 1;
for (i=0; i<lO0; i++)
{
if(fgets(tt,13,fp)==NULL) return 1;
memcpy(xx
,tt,10);
xx
[10]=0;
}
fclose(fp);
return 0;
}
void WriteDat()
{
FILE *fp;
int i;
fp=fopen ("OUT84. DAT", "w");
for (i=0; i<10; i++)
{
fprintf (fp, "%d\n", yy
);
printf ("第%d个人的选票数=%d\n", i+1, yy
);
}
fclose (fp);
}
选项
答案
void CoutRs (void) { int i, count, j; char *pf; for (i=0; i<l0;i++) yy[i]=0; for (i=0; i<l00; i++) { pf=xx [i]; /*指针pf指向字符串的第一个字符*/ count=0; while (*pf) if (*pf==’1’) { count++; /*统计每条记录中1的个数*/ pf++; } else pf++; if (count<=5) /*如果每条记录中1的个数小于等于5则为有效票*/ { pf=xx [i]; /*指针pf指向字符串的第一个字符*/ j=0; while (*pf) /*统计每个人的选票数并把得票数依次存入yy[0]到yy[9]中*/ if (*pf==’1’) { yy[j]+=l; j++; pf++; } else if(*pf==’0’) { j++; pf++; } } } }
解析
本题考查的知识点如下:
(1)二维数组的操作。
(2)指向数组的指针。
在本题中,要先判断选票是否有效。因为记录存放在一个二维数组中,为了简便我们为数组的—组元素定义一个指向该数组每一行数据的指针,例如,char*P=xx[2]。初始时该指针指向该行的第一个元素,指针地址每加1,则指向下一个元素。这样就可以轻松地统计每一个选票。设一变量标记每一个选票中1的个数,若其不大于5,则选票有效。若选票有效,则依次查看哪一个元素为1,在数组yy相应的元素上加l。使用循环实现对所有记录的访问。
转载请注明原文地址:https://kaotiyun.com/show/4OYZ777K
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
在进行某学校教务管理系统的数据库设计时,数据库设计人员设计了如下几个关系模式:系(系号,系名),系号为主码学生(学号,姓名,所在系号),学号为主码课程(课程号,课程名,开课系号),课程号为主码选课(学号,课程号,选课
在数据库动态转储机制中,一般需要使用【12】文件才能将数据库恢复到某一时刻的正确状态。
某商场商品经营管理系统使用SQLServer2008数据库管理系统,此系统上线运行1年后,业务人员使用某统计功能(此功能每月使用一次)时发现速度很慢。该统计功能主要执行的SQL语句如下:SELECT商品号,SUM(销售数量*销售价格)销售额
数据库应用系统在使用过程中,会根据用户的需求及系统运行情况对系统进行升级和改造。关于系统升级改造工作,下列说法错误的是()。
OLAP主要用于支持复杂的分析操作,侧重对决策人员和高层管理人员的数据支持。OLAP的实现方式主要有三种:MOIAP、_______和HOIAP。
索引是数据库中重要的数据结构,关于索引现有下列说法:Ⅰ.在某个查询中带排序的属性有多个时可以考虑在这些属性上建立复合索引Ⅱ.一个表中最多只能有一个主索引或聚集索引Ⅲ.多属性索引中,索引属性的顺序一般按照属性的长度进行排列
浏览器/服务器架构是现阶段非常流行的数据库应用系统架构。在此架构中,应用服务器起到了非常重要的作用。下列关于应用服务器的说法,错误的是()。
从安全性角度考虑,防火墙技术是用来保证数据库应用系统的【2】环境安全的。
在对某商场的顾客进行流失预测分析时,先取得一个顾客样本集S,其模式为(id,al,a2,…,an,c),其中id为顾客的唯一标识,ai(i=1,2,…,n)为顾客的属性,如年龄、性别、消费时间间隔等,c的取值为{流失,未流失}。现有算法A对样本S进行处理,
设有职工表(职工号,姓名,地址1,地址2),其中,职工号为主码。现要求地址1和地址2组合起来不能有重复值。在SQLServer2008环境中有下列创建该表的语句:Ⅰ.CREATETABLE职工表(职工号intPRIMARYKE
随机试题
某新建机场飞行区指标为4F,A施工单位承担跑道施工项目。该机场基层设计为水泥稳定碎石结构层,规范要求基层施工必须采用摊铺机作业,并尽可能消除纵向施工缝。为此,A施工单位拟租赁一台最大摊铺幅宽10m的摊铺机完成基层项目,该机摊铺作业与返回下幅作业起点的行走速
简述国际经济法中的公平互利原则的内涵与主要宗旨。
()提供了一个过程,通过它,组织将它的总目标分解为组织的各部门和成员的具体目标。
关于结核菌素试验,正确的是( )。
王某患肺结核,痰中有结核菌,最简便有效的处理痰的方法是
关于海洋运输货物保险,下列哪一选项是正确的?
关于混凝土或抹灰基层雨期涂刷涂料的基层含水率说法,正确的有()。
贯彻“三个代表”要求.关键在()。
下列关于μC/OS—II操作系统的描述中,错误的是()。
下列描述中错误的是
最新回复
(
0
)