软件工程第二次作业——四则运算结对编程3.0版本(最终版本)

姓名:马柯宇 学号:1500802096
姓名:杨然 学号:1500802102 博客地址:http://www.cnblogs.com/yang-r/p/6837459.html

代码链接:
https://coding.net/u/Apiciallover/p/sizeyunsuan-A/git/tree/master/

  • 界面:

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第1张图片

  • 整数计算功能(加减乘除):

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第2张图片

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第3张图片

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第4张图片

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第5张图片

主要代码:

z=true;
for(int p=0;p<100;p++)
    str[p]=_T("");
for(int p=0;p<100;p++)
{
  int i=(int)rand()%10;
  int j=(int)rand()%9+1;
  int k=(int)rand()%100/25;
  CString str0("");
  switch(k)
  {
    case 0:
      a[p]=i+j;
      str0+=_T("+");
      break;
    case 1:
      a[p]=i-j;
      str0+=_T("-");
      break;
    case 2:
      a[p]=i*j;
       str0+=_T("*");
      break;
    case 3:
      try
      {
        a[p]=i/j;
         str0+=_T("/");
      }
  catch(...)
  {
  p--;
  }

  }        
  
 CString stri((char)(i+48));
 CString strj((char)(j+48));
 str[p]+=stri+=str0+=strj;
  • 真分数计算功能(加减乘除):

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第6张图片

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第7张图片

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第8张图片

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第9张图片

主要代码:

 for(int p=0;p<100;p++)
    str2[p]=_T("");
     for(int p=0;p<100;p++)
{
    int i=(int)rand()%10;
    int j=(int)rand()%10;
    CString strk1("/");
    CString strk2("");
    CString strk3("/");
    CString strk4("(");
    CString strk5(")");
    while(j==0||i>=j)
    {
        i=(int)rand()%10;
        j=(int)rand()%10;
    }
    int x=(int)rand()%10;
    int y=(int)rand()%10;
    while(y==0||x>=y)
    {
        x=(int)rand()%10;
        y=(int)rand()%10;
    }
    int k=(int)rand()%100/25;
    switch(k)
    {
        case 0:
           
            strk2+=_T(")+(");
        
            b[p][0]=i*y+x*j;
            b[p][1]=j*y;
            break;
        case 1:
        
            strk2+=_T(")-(");
            
            b[p][0]=i*y-x*j;
            b[p][1]=j*y;
            break;
        case 2:
          
            strk2+=_T(")*(");
        
            b[p][0]=i*x;
            b[p][1]=j*y;
            break;
        case 3:
            b[p][0]=i*y;
            b[p][1]=j*x;
         
            strk2+=_T(")/(");
        
        }
        
     CString stri((char)(i+48));
 CString strj((char)(j+48));
 CString strx((char)(x+48));
 CString stry((char)(y+48));
 str2[p]+=strk4+=stri+=strk1+=strj+=strk2+=strx+=strk3+=stry+=strk5;
 
}
  • 清屏:

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第10张图片

主要代码:

        CString str("0");
    GetDlgItem(IDC_STATIC)->SetWindowText(str);
    GetDlgItem(DAAN)->SetWindowText(str);
    GetDlgItem(sdfgsdgs)->SetWindowText(str);
    GetDlgItem(truejieguo)->SetWindowText(str);
    GetDlgItem(shijian)->SetWindowText(str);
  • 约分功能:

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第11张图片

  • 判断对错功能:

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第12张图片

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第13张图片

  • 统计用户练习题数目以及正确数量:

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第14张图片

主要代码(判断对错和统计出题数以及正确题数):

   UpdateData(TRUE);

CString strm[100],strn[100];
strm[n].Format(_T("%d"),n);
if(z)
{
    GetDlgItem(shumu)->SetWindowText(strm[n]);
    int i = _ttoi(o);
    if(i==a[n-1])
    {
        GetDlgItem(sdfgsdgs)->SetWindowText(_T("回答正确"));
         x=x+1;
     strn[n].Format(_T("%d"),x);
   GetDlgItem(zhengque)->SetWindowText(strn[n]);

    }
    else
    {
        GetDlgItem(sdfgsdgs)->SetWindowText(_T("回答错误"));
         strn[n].Format(_T("%d"),x);
  GetDlgItem(zhengque)->SetWindowText(strn[n]);
    
    }
}


else
{
    GetDlgItem(shumu)->SetWindowText(strm[n]);
    int x1,y1;
    CString z1;
    CString m1;
    int i=0;
    while(o.GetAt(i)!='/'&& o.GetAt(i)!='\0')
    {
        z1+=o.GetAt(i);
        i++;
    }
    if(o.GetAt(i)=='\0'||o.GetAt(i+1)=='\0')
    {
        GetDlgItem(IDC_EDIT5)->SetWindowText(_T("请重新输入"));
    }
    else
    {
        x1=_ttoi(z1);
        i++;
        while(o.GetAt(i)!='\0')
        {
            m1+=o.GetAt(i);
            i++;
        }
        y1=_ttoi(m1);
        if(x1==b[n-1][0]&&y1==b[n-1][1])
        {
            GetDlgItem(sdfgsdgs)->SetWindowText(_T("回答正确"));
              x=x+1;
     strn[n].Format(_T("%d"),x);
     GetDlgItem(zhengque)->SetWindowText(strn[n]);
        }
        else
        {
            GetDlgItem(sdfgsdgs)->SetWindowText(_T("回答错误"));
            strn[n].Format(_T("%d"),x);
  GetDlgItem(zhengque)->SetWindowText(strn[n]);


        }
    }


}
  • 倒计时:
    (每个题目必须在20秒内完成,若完不成则自动出下一题并得0分记计算错误。)

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第15张图片

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第16张图片

主要代码:

   void CsizeyunsuanDlg::OnBnClickedButton7()
  {
    
    SetTimer(1,1000,NULL);
    
  }
  void CsizeyunsuanDlg::OnTimer(UINT nIDEvent)
 {
     i--;
     strt[i].Format(_T("%d"),i);
     CString strt(strt[i]);
     GetDlgItem(shijian)->SetWindowText(strt);
     if(i==0)
        {i=20;
     OnBnClickedButton5();
     }
      

 }
  • 结对编程照片

软件工程第二次作业——四则运算结对编程3.0版本(最终版本)_第17张图片

  • 心得体会
    第一次体会这种编程方式,感觉还是受益很大的。从前都是自己一个人编程,所以在编程的时候比较随意,但是在结对编程的时候就要考虑小伙伴的感受和想法。通过这次的结对编程,我深深体会到“多一个人多一份力量”的这句话,两个人的思维结合在一起使难题解决得更快,并且更加容易发现错误。而且由于两个人互相监督,所以基本上不会出现玩手机等现象。但是由于两个人的思路和意见不统一的时候会花费很多时间去统一意见选出一个比较好的。

转载于:https://www.cnblogs.com/mkyz/p/6837701.html

你可能感兴趣的:(软件工程第二次作业——四则运算结对编程3.0版本(最终版本))