zoukankan      html  css  js  c++  java
  • 计算与软件工程 作业二

    作业一#

    1.预习##

    第二部分主要介绍了个人软件流程,职业发展,个人绩效的衡量和提高,软件开发是工程还是艺术或其他几个部分。
    首先,软件开发是由一个团队组成的,团队中的每一个人负责不同的工作,团队的流程就是将个人的劳动成果有效组织起来。因此,个人也有个人的软件流程,举个例子,开发人员在团队中的流程包括:

    • 理解问题或任务
    • 提出多种解决办法并估计工作量(其中包括寻找以前的解决方案,因为很多工作是重复性的–例如实现某些类似的web页面)
    • 与相关角色交流解决问题的提案,决定最终方案
    • 执行, 把想法变成实际中能工作的代码
    • 修复缺陷, 对结果负责

    因此每个人的工作效率及质量都会影响到整个团队,所以对于一名新人软件工程师,一定要努力提高自己,掌握具体技术,将理论知识掌握的同时要注重实践,不要只是"纸上谈兵",用许多书本知识来填补实战经验的空缺,而是用实践经验来丰富自己。同时有自己的原创思想,也就是软件工程思想的提高。

    其次,关于软件开发的工作量和质量怎么衡量有四个方面:
    1.项目/任务的大小
    2.花费的时间
    3.质量的情况
    4.是否按时交付

    接下来是关于PSP的介绍

    个人软件过程(Personal Software Process,PSP)是一种可用于控制、管理和改进个人工作方式的自我持续改进过程,是一个包括软件开发表格、指南和规程的结构化框架。PSP与具体的技术(程序设计语言、工具或者设计方法)相对独立,其原则能够应用到几乎任何的软件工程任务之中。PSP能够说明个体软件过程的原则; 帮助软件工程师作出准确的计划;确定软件工程师为改善产品质量要采取的步骤;建立度量个体软件过程改善的基准;确定过程的改变对软件工程师能力的影响。

    PSP的阶段包括:1.计划 2.开发 3.报告 4.总共花费的时间
    PSP的特点:
    •不局限于某一种软件技术 (如编程语言),而是着眼于软件开发的流程,这样不同应用的工程师可以互相比较。
    •不依赖于考试,而主要靠工程师自己收集数据,然后统计提高。
    •在小型,初创的团队中,高质量的项目需求很难找到,这意味着给程序员的输入质量不高,在这种情况下,程序员的输出 (程序/软件) 往往质量不高,然而这并不能全部由程序员负责。
    •PSP 依赖于数据
    •需要工程师输入数据,记录工程师的各项活动,这本身就需要不小的代价。
    •如果数据不准确或有遗失,怎么办?让工程师编造一些?
    •如果一些数据不利于工程师本人 (例如: 花很多时间修改缺陷),我们怎么能保证工程师能如实地记录这些数据呢?
    •PSP的目的是记录工程师如何实现需求的效率,而不是记录顾客对产品的满意度

    2.个人程序##

    代码###

    #include<iostream>
    #include<cstdlib>
    #include<ctime>
    using namespace std;
    void main()
    {
        int a0[1000],b0[1000],c0[1000],a1[1000],b1[1000],c1[1000],a2[1000],b2[1000],c2[1000],a3[1000],b3[1000],c3[1000],C[1000],a,b,c;
        int i,j,A0,A1,A2,A3,B0,B1,B2,B3;
        int num,grade,k;
    	int	line=1;
        int min,max,m;
        int X,Y,Z;
        k=0;
        A0=0;A1=0;A2=0;A3=0;
        B0=0;B1=0;B2=0;B3=0;
        cout<<"四则运算"<<endl;
        cout<<"请输入出题数目:"<<endl;
        cin>>num;
        cout<<"请选择年级(1-5年级):"<<endl;
    	cin>>grade;
        cout<<"是否有乘除法  有请输1 无请输0 :"<<endl;
        cin>>X;
        while(1)                           
        {
            if(X != 1&&X != 0)
            {
                cout<<"输入不合法,请重新输入:";
                cin>>X;
            }
            else
                break;
        }
        
        cout<<"加减法是否要有负数 有请输1 无请输0 :"<<endl;
        cin>>Y;
        while(1)                           
        {
            if(Y != 1&&Y != 0)
            {
                cout<<"输入不合法,请重新输入:";
                cin>>Y;
            }
            else
                break;
        }
        
        cout<<"除法结果是否有余数 有请输1 无请输0 :"<<endl;
        cin>>Z;
        while(1)                          
        {
            if(Z != 1&&Z != 0)
            {
                cout<<"输入不合法,请重新输入:";
                cin>>Z;
            }
            else
                break;
        }
    
        cout<<"请输入题目数字的范围a和b:"<<endl;
        cin>>min>>max;
        while(1)                          
        {
            if(min>=max)
            {
                cout<<"输入不合法,请重新输入:";
                cin>>min>>max;
            }
            else
                break;
        }
        m=max-min+1;
        for(i=0;i<1000;i++)
        {
            a0[i]=0;b0[i]=0;
            a1[i]=0;b1[i]=0;
            a2[i]=0;b2[i]=0;
            a3[i]=0;b3[i]=0;
        }
        for(i=0;;i++)
        {
            a=min+rand()%m;
            b=min+rand()%m;
            c=rand()%4;
            if(X==0)              
            {
                if(c==2||c==3)
                    continue;
            }
            if(Y==0)              
            {
                if(c==0)
                {
                    if(a+b<0)
                        continue;
                }
                else if(c==1)
                {
                    if(a-b<0)
                        continue;
                }
            }
            if(Z==0)             
            {
                if(c==3)
                    if(0 != a%b)
                        continue;
            }
            
            if(c==0)                     
            {
                for(j=0;j<=A0;j++)
                {
                    if(a==a0[j]&&b==b0[j])
                    {
                        B0++;break;
                    }
                }
                if(B0>0)
                {
                    B0=0;continue;
                }
                else
                {
                    a0[A0]=a;
                    b0[A0]=b;
                    c0[A0]=a+b;
                    A0++;
                }
            }
            else if(c==1)             
            {
                for(j=0;j<=A1;j++)
                {
                    if(a==a1[j]&&b==b1[j])
                    {
                        B1++;break;
                    }
                }
                if(B1>0)
                {
                    B1=0;continue;
                }
                else
                {
                    a1[A1]=a;
                    b1[A1]=b;
                    c1[A1]=a+b;
                    A1++;
                }
            }
            else if(c==2)                
            {
                for(j=0;j<=A2;j++)
                {
                    if(a==a2[j]&&b==b2[j])
                    {
                        B2++;break;
                    }
                }
                if(B2>0)
                {
                    B2=0;continue;
                }
                else
                {
                    a2[A2]=a;
                    b2[A2]=b;
                    c2[A2]=a+b;
                    A2++;
                }
            }
            else                    
            {
                if(b==0)
                    continue;
                for(j=0;j<=A3;j++)
                {
                    if(a==a3[j]&&b==b3[j])
                    {
                        B3++;break;
                    }
                }
                if(B3>0)
                {
                    B3=0;continue;
                }
                else
                {
                    a3[A3]=a;
                    b3[A3]=b;
                    c3[A3]=a+b;
                    A3++;
                }
            }
            if(num==A0+A1+A2+A3)          
                break;
        }
    
        for(i=0;i<A0;i++)                        
        {
            k++;
            if(a0[i]<0)
                cout<<"("<<a0[i]<<")";
            else
                cout<<a0[i]<<" ";
            cout<<"+";
            if(b0[i]<0)
                cout<<"("<<b0[i]<<")";
            else
                cout<<" "<<b0[i]<<" ";
            cout<<"=";
            if(k%line==0)
                cout<<endl;
            else
                cout<<"	";
        }
        for(i=0;i<A1;i++)                     
        {
            k++;
            if(a1[i]<0)
                cout<<"("<<a1[i]<<")";
            else
                cout<<a1[i]<<" ";
            cout<<"-";
            if(b1[i]<0)
                cout<<"("<<b1[i]<<")";
            else
                cout<<" "<<b1[i]<<" ";
            cout<<"=";
            if(k%line==0)
                cout<<endl;
            else
                cout<<"	";
        }
        for(i=0;i<A2;i++)                    
        {
            k++;
            if(a2[i]<0)
                cout<<"("<<a2[i]<<")";
            else
                cout<<a2[i]<<" ";
            cout<<"*";
            if(b2[i]<0)
                cout<<"("<<b2[i]<<")";
            else
                cout<<" "<<b2[i]<<" ";
            cout<<"=";
            if(k%line==0)
                cout<<endl;
            else
                cout<<"	";
        }
        for(i=0;i<A3;i++)                 
        {
            k++;
            if(a3[i]<0)
                cout<<"("<<a3[i]<<")";
            else
                cout<<a3[i]<<" ";
            cout<<"/";
            if(b3[i]<0)
                cout<<"("<<b3[i]<<")";
            else
                cout<<" "<<b3[i]<<" ";
            cout<<"=";
            if(k%line==0)
                cout<<endl;
            else
                cout<<"	";
        }
        cout<<"输入结果:"<<endl;
        for(i=0;i<num;i++)
            cin>>C[i];
        int t=0,correct=0;
        for(i=0;i<A0;i++)
        {
            if(c0[i]==C[t])
            {t++;correct++;}
            else
            {
                t++;
                cout<<"第"<<t<<"题答错!"<<endl;
            }
        }
        for(i=0;i<A1;i++)
        {
            if(c1[i]==C[t])
            {t++;correct++;}
            else
            {
                t++;
                cout<<"第"<<t<<"题答错!"<<endl;
            }
        }
        for(i=0;i<A2;i++)
        {
            if(c2[i]==C[t])
            {t++;correct++;}
            else
            {
                t++;
                cout<<"第"<<t<<"题答错!"<<endl;
            }
        }
        for(i=0;i<A3;i++)
        {
            if(c3[i]==C[t])
            {t++;correct++;}
            else
            {
                t++;
                cout<<"第"<<t<<"题答错!"<<endl;
            }
        }
        if(line==correct)
            cout<<"回答正确!"<<endl;
    	system("pause");
    	return 0;
    }
    

    执行结果###

    作业二#

    托管于gitee上的链接
    https://gitee.com/shen_ling_ha/codes/6kpoa8f4ihqnsrl3v1cw969

  • 相关阅读:
    c#类的小小理解
    sql语句:保留要害字的问题.例如 size,text,user等
    c#2005做新闻发布系统心得
    asp 遇到过的问题集锦,附加asp语句添加数据库和生成表,asp命令更改指定文件的文件名,asp值传递的应用091116小结
    dropdownlist控件失去焦点的小应用和函数substr
    获得当前应用程序路径C#03
    模糊查询简单分析,得出sql语句
    20080905经典的DataReader对象解读+几种对数据库的操作的命令,20100111update read db example
    Servlet 容器的工作原理 ( 二 )
    手低眼高 初学者学习Hibernate的方法
  • 原文地址:https://www.cnblogs.com/shenlingha/p/12387278.html
Copyright © 2011-2022 走看看