问题 选择题

下列除去杂质的方法中,正确的是

序号物质杂质除去杂质的方法
A.Cu  CuO    通入一氧化碳,加热
B.CO2H2O将混合气通过盛氢氧化钠固体的装置
C.FeSO4溶液CuSO4加入足量锌粒,充分反应,过滤
D.NaOH溶液Na2CO3加入过量的稀盐酸

答案

答案:A

题目分析:通过化学方法除杂质有2个原则:1、加入的物质只能与杂质反应,2、不能引入新的杂质, A、除去Cu中的CuO杂质,通入一氧化碳,加热,发生反应:CO+ CuO 加热 Cu + CO2,可以达到目的,正确,B、除去CO2中H2O,通过NaOH固体虽然能干燥水分,但也会与CO2反应,错误,C、除去FeSO4溶液中的CuSO4,加入过量的锌粉,发生反应:Zn+CuSO4==Cu+ZnSO4,引入了新的杂质ZnSO4,错误,D、除去NaOH溶液中Na2CO3,加入过量的稀盐酸,稀盐酸既会与NaOH反应,也会与Na2CO3反应,错误,故选A

问答题

【说明】 某超市集团为发展业务向社会公开招聘N个工种的工作人员,每个工种各有不同的编号(1至M)和计划招聘人数。每位应聘者需申报两个工种,并参加集团组织的考试。该集团公司将按应聘者的成绩从高分至低分的顺序进行排队录取。具体录取原则是:从高分到低分依次对每位应聘者先按其第一志愿录取;当不能按其第一志愿录取时,便将他的成绩扣去5分后,重新排队,并按其第二志愿录取。 以下C程序为输出各工种实际招聘的应聘人员,每个工种都保留一个录取者的有序队列。录取处理循环直至招聘额满或已对全部应聘者都作了录取处理后跳出。 C程序中,类型STU包含有应聘者的基本信息:编号、成绩、志愿、排队成绩和录取志愿号。数组 rzl)的每个元素对应一个工种,包含有计划招聘人数和已录取的人数。【C程序】#include#define N 36#define EDMARK 5typedef struct stu { int no, total, z[2], sortm, zi; struct stu *next;} STU;struct rznode { int lmt, count; STU *next;} rz [N];STU *head = NULL, *over = NULL;int allFILE *fp;char dataf [ ] = "zp2008.dat" ;print(STU *p){ for (;p!=NULL; p = p->next) printf( "%d(%d) \t" , p->no, p->total}insert(STU **p, STU *u){ STU *v, *q; for (q = *p;q != NULL; v = q , (1) ) if (q-> sortm < u->sortm) break; if ( q == *p) (2) ; else (3) ; u->next = q ;}main ( ){ int zn, i, no, total, zl, z2 ; STU *p, *v, *q; fp = fopen(dataf, "r" ); if (fp == NULL) { printf ("Can’t open file %s.kn" ,dataf); exit (0); } fscanf (fp, "%d" ,&zn); for (all = 0, i = 1; i <= zn; i++) { fscanf (fp, "%d", &rz [ i ].lmt ; rz[i].count = 0; rz[i].next = NULL; all += (4) ; } for (;;) { if (( fscanf(fp, "%d%d%d%d" ,&no,&total,&zl,&z2)) != 4 ) break; p = ( STU *) malloc (sizeof (STU)); p->no = no; p->total = p->sortm = total; p->zi = 0; p->z[0] = z1; p->z[1] = z2; (5) ; } fclose (fp); for (;all && head != NULL;) { p = head; head = head->next; if (rz[p->z[p->zi]].count < (6) ) { rz[p->z[p->zi]].count ++; insert(&rz[p->z[p->zi]].next,p); all--; continue; } if (p->zi >= 1 ) { p->next = over; over = p; continue; } p->sortm -= DEMARK; (7) ; insert(&head,p); } for (i = 1; i <= zn; i++ ) { printf("%d:\n" ,i); print( rz[i ].next); printf(" \n"); } printf( "over:\n" ); print(head); print(over); printf(" \n");}

单项选择题