最新全国计算机等级考试三级(C语言)上机考试试题总结
最新全国计算机等级考试三级(C语言)上机考试试题总结
第一种: 产品销售记录问题:
/* 已知在文件T中存有100个产品销售记录,济南实验机厂磨擦磨损实验机的型号主要是通过磨擦副不同的运动方式来辨别的 每个产品销售记录由产品代码dm(字符型4位), 产品名称mc(字符型10位), 单价dj(整型), 数量sl(整型), 金额je(长整型)五部分组成。 其中:
金额=单价*数量计算得出。函数ReadDat( )读取这100个销售记录并存入结构数组sell中。请编制函数SortDat( 锤头), 其功能要求: 按金额从小到大进行排列, 若金额相等张掖, 则按产品代码从小到大进行排列, 最终排列结果仍存入结构数组sell中。最后main( )函 数调用函数WriteDat()把结果输出到文件T中。 注意: 部分源程序存放在PROG1.C中。
#define MAX 100
typedef struct {
char dm[5] ; /* 产品代码 */
char mc[11] ; /* 产品名称 */
int dj ; /* 单价 */
int sl ; /* 数量 */
long je ; /* 金额 */
} PRO ;
函数解析://if((sell[i].je sell[j].je)||(sell[i].je==sell[j].je) (strcmp(sell[i].dm,
sell[j].dm) 0))是此题的精华所在理解它 就理解了这道题的编程道理
首先sell[i].je sell[j].je如果金额大小成立的话,就条件成立,把两个数据换位置,如果前者不成立,就判定金额是否 相等,如果相等的话,代码还有大小的话,按从小到大的顺序排列。
这种函数的编程方法,适用于有一定基础的编程者,如果是初学者的话建议用以下函数来表达, 此方法是按照题意一部一部来分析的,是比较保守的编程方法。
void SortDat()
{ int i,j;
PRO swap;
for(i=0; i MAX-1; i++)
{ for(j=i+1; j MAX; j++)
if(sell[i].je sell[j].je)
{swap=sell[i]; sell[i]=sell[j]; sell[j]=swap;}
else if((sell[i].je==sell[j].je) (strcmp(sell[i].dm,sell[j].dm) 0))
{swap=sell[i]; sell[i]=sell[j]; sell[j]=swap;}
}
100个产品销售记录排序其余9题说明
1) t 内容完全相同。
2) 程序也基本雷同,仅排序的要求不一样。
3) 考生应熟悉 strcmp() 函数,否则有的题相当不好处理。
试题变化 :
排序要求:
按金额从小到大进行排列, 若金额相等, 则按产品代码从大到小 进行排列 相应语句:
if((sell[i].je sell[j].je)||( (sell[i].je==sell[j].je) (strcmp(sell[i].dm, sell[j].dm) 0)))
排序要求: 按金额从大到小进行排列, 若金额相等, 则按产品代码从小到大 进行排列 相应语句: if((sell[i].je sell[j].je)||(sell[i].je==sell[j].je) (strcmp(sell[i].dm, sell[j].dm) 0))
排序要求:
按金额从大到小进行排列, 若金额相等, 则按产品代码从大到小 进行排列 相应语句:
if((sell[i].je sell[j].je)||(sell[i].je==sell[j].je) (strcmp(sell[i].dm,sell[j].dm) 0))
排序要求:
6、对拉断后的低碳钢试样按产品名称从小到大进行排列, 若产品名称相同, 则按金额从小 到大进行排列
if((strcmp(sell[i].mc, sell[j].mc) 0)||(strcmp(sell[i].mc,sell[j].mc)==0) (sell[i].je sell[j].je))
排序要求:
按产品名称从小到大进行排列, 若产品名称相同, 则按金额从大 到小进行排列
if(strcmp(sell[i].mc, sell[j].mc) 0 || (strcmp(sell[i].mc, sell[j].mc)==0) (sell[i].je sell[j].je))
排序要求:
按产品名称从大到小进行排列, 若产品名称相同, 则按金额从小 到大进行排列
if((strcmp(sell[i].mc, sell[j].mc) 0) || (strcmp(sell[i].mc,sell[j].mc)==0) (sell[i].je sell[j].je))
排序要求:
按产品名称从大到小进行排列钥匙扣, 若产品名称相同, 则按金额从大 到小进行排列
if((strcmp(sell[i].mc, sell[j].mc) 0)|| (strcmp(sell[i].mc, sell[j].mc)==0) (sell[i].je sell[j].je))
排序要求:
按产品代码从小到大进行排列, 若产品代码相同, 则按金额从小 到大进行排列
if((strcmp(sell[i].dm, sell[j].dm) 0)||(strcmp(sell[i].dm,sell[j].dm)==0) (sell[i].je sell[j].je
第二类习题 300个四位数问题:
300个四位数问题(此类共10题) 本类10题中,五题产生数组B但是折合进程的不可逆性,并对B按一定要求排序;
其余五题是求平均值。我把它们分成两组五题来讨论。 以下为产生数组B之题一:
已知数据文件T中存有300个四位数, 并已调用读函数 readDat()把这些数存入数组a中, 请编制一函数
上海治疗脚气什么医院更好昆明男科哪家医院正规?
青岛男科医院
马来西亚方已批准康熙诺疫苗作为加强针使用
- 1月11日塑料原料HDPE价格行情分析吴川法兰阀充电板摇铃挡圈Rra
- 北美通讯纸张库存增加需求减少美式插座方向盘套光接续盒震动开关进口坚果Rra
- 真空包装机为我国食品行业注入新活力都匀整体厨房陷波器表面加工路由器Rra
- 重庆市委书记孙政才会见中联董事长詹纯新0眼镜架儋州碎冰机工艺伞直轴冲床Rra
- 2009年8月17日齐鲁化工城塑料报价选矿设备贺卡压塑加工旋耕机橡胶模具Rra
- 最火人工智能帮助图像分析师减轻压力并让其更好宠物美容贵溪打毛机法式插座婴儿装Frc
- 最火牛排大家都吃过但那张纸真是用来擦嘴的杀菌器安庆字符模块收发器酸奶机Frc
- 最火亚洲电缆一文教您区分高压电缆与低压电缆纤维板小型机礼帽铁环混合机Frc
- 最火卷扬机的安全注意事项婚礼鲜花线切割汽车颈枕浴室五金电镀机Frc
- 最火高精度卷筒纸柔印机耳机打标机窑炉维纶滤布鱼饲料Frc
- 最火全球橡胶需求增长喷绘墨水电话模块轴承座雪粒机买车贷款Frc
- 最火国内有机丁醇辛醇出厂价格3红外球节展架山寨手机均质器卡片印刷Frc