一起答

2011年软件设计师考试考前密卷(六)-下午试题

如果您发现本试卷没有包含本套题的全部小题,请尝试在页面顶部本站内搜索框搜索相关题目,一般都能找到。
  1. ●试题六

    【说明】

    下面是一个Applet程序,其功能是在绘图区域中通过鼠标的移动来绘制直线,并且有清除绘图区域按钮,用来清除已经绘制的图像。

    程序运行结果如图5所示。

    图5

    import javA.awt.*;

    import javA.applet.*;

    /*

    */

    public class ex6_7 extends Applet{

    private Button btn;

    private boolean bDraw, bClear;

    private int upX, upY,downX, downY;

    public void init(){

    setLayout(null);

    bClear = false;

    bDraw = false;

    btn = new Button("clear");

    btn.reshape(250, 150, 70, 30);

    add(btn);

    }

    public void paint(Graphics g){

    if(bClear){

    g.clearRect(0, 0, getSize().width, getSize().height);

     (1) ;

    }

    if(bDraw){

    g.drawLine( (2) );

    bDraw = false;

    }

    }

    public void update(Graphics g){

     (3) ;

    }

    public boolean mouseDown(Event event, int x, int y){

    downX = x;

    downY = y;

    return true;

    }

    public boolean mouseUp(Event event, int x, int y){

    upX = x;

    upY = y;

     (4) ;

    repaint();

    return true;

    }

    public boolean action(Event event, Object object){

    if ( (5) ){

    bClear = true;

    repaint();

    }

    return true;

    }

    }

    ex6_7.html

    ex6_7

       code=" ex6_7.class" width=800 height=400 >

  2. ●试题五

    阅读下列程序说明,将应填入(n)处的字句写在答卷纸的对应栏内。

    【程序说明】

    对于一个公司的雇员来说,无非有3种:普通雇员、管理人员和主管。这些雇员有共同的数据:名字、每小时的工资,也有一些共同的操作:数据成员初始化、读雇员的数据成员及计算雇员的工资。但是,他们也有不同。例如,管理人员除有这些共同的特征外,有可能付固定薪水,主管除有管理人员的共同特征外,还有其他物质奖励等。3种雇员中,管理人员可以看作普通雇员的一种,而主管又可以看作管理人员的一种。我们很容易想到使用类继承来实现这个问题:普通雇员作为基类,管理人员类从普通雇员类中派生,而主管人员类又从管理人员类中派生。

    下面的程序1完成上述各个类的定义,并建立了3个雇员(一个普通雇员、一个管理人员和一个主管)的档案,并打印出各自的工资表。将"程序1"中的成员函数定义为内联函数,pay成员函数定义为虚函数,重新完成上述要求。

    【程序1】

    //普通雇员类

    class Employee

    {

    public:

    Employee(char*theName,float thePayRate);

    char*getName()const;

    float getPayRate()const;

    float pay(float hoursWorked)const;

    protected:

    char*name;//雇员名称

    float payRate;//薪水等级

    };

    Employee::Employee(char*theName,float thePayRate)

    {

    name=theName;

    payRate=thePayRate;

    }

    char*Employee::getName() const

    {

    return name;

    }

    float Employee::getPayRate()const

    {

    return payRate;

    }

    float Employee::pay(float hoursWorked)const

    {

    return hoursWorked*payRate;

    }

    //管理人员类

    class Manager∶public Employee

    {

    public:

    //isSalaried付薪方式:true付薪固定工资,false按小时付薪

    Manager(char*theName,float thePayRate,bool isSalaried);

    bool getSalaried()const;

    float pay(float hoursWorked)const;

    protected:

    bool salaried;

    };

    Manager::Manager(char*theName,float thePayRate,bool isSalaried)

    ∶Employee(theName,thePayRate)

    {

    salaried=isSalaried;

    }

    bool Manager::getSalaried() const

    {

    return salaried;

    }

    float Manager::pay(float hoursWorked)const

    {

    if(salaried)

    return payRate;

    /*else*/

    return Employee::pay(hoursWorked);

    }

    //主管人员类

    class Supervisor:public Employee

    {

    public:

    Supervisor(char*theName,float thePayRate,float theBouns):

    Employee(theName,thePayRate, (1) ),bouns(theBouns){}

    float getBouns()const{return bouns;}

    float pay(float hoursWorked)const

    return (2) ;

    }

    protected:

    float bouns;

    }

    #include"iostream.h"

    void main()

    {

    Employee e("Jack",50.00);

    Manager m("Tom",8000.00,true);

    Supervior s("Tanya",8000.00,8000.00);

    cout<<"Name:"<

    cout<<"Pay:"<

    cout<<"Name:"<

    cout<<"Pay:"<

    cout<<"Name:"<

    cout<<"Pay:"<

    }

    【程序2】

     #include"employee.h"

     //普通雇员类

     class Employee

     {

     public:

    //构造函数

    Employee(string theName,float thePayRate):

    name(theName),payRate(thePayRate){}

    //取雇员姓名

    string getName() const{returnname;}

    //取雇员薪水等级

    float getPayRate()const{return payRate;}

    //计算雇员薪水

    virtual float pay(float hoursWorked)const{return (3) ;}

    protected:

    string name;//雇员名称

    float payRate;//薪水等级

    };

    //管理人员类

    //继承普通雇员类

    class Manager:public Employee

    {

    public:

     //构造函数

     //isSalaried标识管理人员类的付薪方式

     //true 按阶段付薪(固定工资)

     //false按小时付薪

    Manager(string theName,float thePayRate,bool isSalaried):

    Employee(theName,thePayRate),salaried(isSalaried){}

     //取付薪方式

    bool getSalaried()const{return salaried;}

     //计算薪水

    virtual float pay(float (4) )const;

    protected:

    bool salaried;

    };

    float Manager::pay(float hoursWorked)const

    {

    if(salaried)//固定付薪方式

    return payRate;

    else//按小时付薪

    return (5)  ; }

    //主管人员类

    class Supervisor: (6) 

    {

    public:

    //构造函数

    Supervisor(string theName,float thePayRate,float theBouns):

    Manager(theName,thePayRate,true),bouns(theBouns){}

     //取奖金数额

    float getBouns()const{return bouns;}

     //计算薪水

    virtual float pay(float hoursWorked)const

    {

    retum payRate+bouns;

    }

     (7) 

    float bouns;

    }

    #include"employee.h"

    #include"iostream.h"

    void main()

    {

     (8) *ep[3];ep[0]=new Employee("Jack","50.00");

    ep[1]=new Manager("Tom","8000.00",true);

    ep[2]=new Supervior("Tanya","8000.00","8000.00");

    for(int i=0;i<3;i++){

    cout<<"Name:"<< (9) <

    cout<<"Pay:"<< (10) <

     }

    }

  3. ●试题四

    阅读下列程序说明,将在空缺处填入正确的内容。

    【程序说明】

    定义一个多边形结构:struct polygon实现以下内容: (1) 建立该结构的链表:create函数是创建链表,每输入一个结点的数据,就把该结点加入到链表当中,它返回创建的链表的头指针。 (2) 显示链表的各个结点数据:结点数据包括:多边形顶点数、各顶点的纵横坐标、当多边形顶点数为0时,链表创建结束。 (3) 编写一个函数disp,删除链表中的所有结点。需要注意的是:要先释放结点数据内存,再删除结点,如果在释放结点数据内存单元之前删除结点,则无法找到结点数据内存单元的地址,也就无法释放数据的内存单元。

    【程序】

    #include"iostream.h"

    #include"iomanip.h"

    struct polygon

    {

    int n;

    int *x;

    int *y;

    polygon *next;

    };

    void Push(polygon*& head,int n)

    {

    polygon*newNode=new polygon;

    newNode=new polygon;

    newNode->next= (1) ;

    newNode->x=new int[n];newNode->y=new int[n];newNode->n= (2) ;

    for(int i=0;i<= (3) ;i++){

    cout<<"请输入多边形各顶点x、y坐标,坐标值之间用空格分隔:";

    cin>>newNode->x[i]>>newNode->y[i];}

     (4) =head;//在head前不需要额外的*

    head=newNode;

    }

    polygon *create()

    {

    polygon*head=NULL;

    polygon*tail;

    int n;

    cout<<"请输入多边形顶点的个数(顶点个数为0时结束):";

    cin>>n;

    if(n==0)return (5) ;

    Push(head, (6) ;

    tail=head;

    cout<<"请输入多边形顶点的个数(顶点个数为0时结束):";

    cin>>n;

    while(n!=0)

    {

    Push(tail->next, (7) ;//在tail->next增加结点

    tail=tail->next;//advance tail to point to last node

    cout<<"请输入多边形顶点的个数(顶点个数为0时结束):";

    cin>>n;

    }

    return head;

    }

    void disp(polygon*head)

    {

    int i,No=1;

    cout<

    while(head!=NULL)

    {

    cout<<"第"<

    for(i=0;i<=head->n-1;i++)

    cout<x[i]<y[i]<

     (8) ;

    head= (9) ;

    }//Match while statement

    }

    void del(polygon*head)

    {

    polygon*p;

    while(head!=NULL)

    {

    p= (10) ;

    head=head->next;

    delete p->x;

    delete P->y;

    deletep;

    }//Match while statement

     }

     void main()

     {

    polygon*head;

    head=create();

    disp(head);

    del(head);

    }

  4. ●试题三

    阅读下列说明和E-R图,回答问题1~3。

    【说明】

    设有关于银行借贷管理系统的E-R图(如图4所示)。图中矩形表示实体,圆表示属性,双圆表示关键字属性,菱形表示实体间的联系。为了答题的方便,图中的实体和属性同时给出了中英文说明,回答问题时只需写出英文名即可。

    图4银行借贷管理系统E-R图

    【问题1

    根据E-R图中给出的词汇,按照"有关模式名(属性1,属性2,…)"的格式,将此E-R图转换为关系模式,并指出每个关系模式中的主码和外码,其中模式名根据需要取实体名或联系名。要求其中的关系模式至少属于第三范式。

    【问题2】

    如下的SQL语言用于查询"在该银行中一笔贷款贷给多个(至少2个)客户的所有贷款号和发放贷款的支行名称"的不完整语句,请在空缺处填入正确的内容。

    SELECT Borrow.Lno,Bname

    FROM Borrow,Loan

    WHERE (1) 

    GROUP BY Borrow.Lno

    HAVING (2) ;

    【问题3】

    假设这个银行有若干个节点,每个节点运行一个数据库系统。假设这些节点之间惟一的交互式用电子方式相互传送款项,这样的系统是分布式数据库系统吗?为什么?

  5. ●试题一

    阅读下列说明和数据流图,回答问题1~问题3。

    【说明】

    某考务处理系统主要功能是考生管理和成绩管理:

    1.对考生送来的报名表进行检查。

    2.对合格的报名表编好准考证号码后将准考证送给考生,将汇总后的考生名单送给阅卷站。

    3.对阅卷站送来的成绩表进行检查,并根据考试中心指定的合格标准审定合格者。

    4.填写考生通知单(内容包含该考生的准考证号、姓名、各课程成绩及最终合格/不合格标志),送给考生。

    5.根据考生信息及考试成绩,按地区、年龄、文化程度和职业进行成绩分类统计及试题难度分析,产生统计分析表。

    考务处理系统的顶层图如图1所示,第0层图如图2所示,加工2子图如图3所示。

    【数据流图】

    图1顶层图

    图2 0层图

    图3加工2子图

    【问题1】

    指出哪张图的哪些文件可以不必画出。

    【问题2】

    数据流图1-3中缺少3条数据流,请直接在图中添加。

    【问题3】

    根据系统功能和数据流图填充下列数据字典条目中的 (1) 和 (2) :

    试题得分表=准考证号+{课程名+成绩}

    考生名册=报名号+准考证号+姓名+通信地址+出生年份+文化程度+职业

    考生通知单= (1) 

    报名表= (2) 

  6. ●试题二

    阅读以下说明,回答问题,将解答写在试卷的对应栏内。

    【说明】

    某公司要开发一个销售管理系统,该系统的主要功能是:处理客户和销售员送来的订单;工厂是根据订货安排生产的,交出货物同时开出发票,收到客户付款后,根据发票存根进行应收款处理。每张订单由订单号,若干头信息和订单细节组成。一张订单可定购多种产品,工厂对大宗订货给予优惠。每种产品都规定了不同订货数量的折扣。

    根据上述要求公司的销售部王经理写下了以下数据表结构:

    客户:(客户号,客户名,地址,电话)

    订单:(订单号,客户号,产品号,订货数,订货日期,交货日期,金额)

    应收账款:(客户号,订单号,发票号,应收金额,支付日期,支付金额,当前余额)

    产品描述:(产品号,产品名,单价,重量)

    折扣规则:(产品号,订货量,折扣)

    【问题1】

    上表中带下划线的为主码。请为还没有确定主码或是主码不合理的数据表选定最合适的主码。

    【问题2】

    上面的关系模式中还有不是第二范式的,请将其转为第二范式。并确定新数据表的主码。