附:Github的链接:https://github.com/mingyueanyao/object-oriented/tree/master/Calculator

1、初见题目:

第一眼看到题目最大的困难就是有很多东西看不懂,因为我C++的自学实际上是很随意的(说好不强求的),截止到题目出现,C++远征攻略的远征起航还没有看完,基本上是一周一章(要是没叫总结的话,说不定还要再看一遍)。。。所以当务之急是赶紧把要用到的东西看完(在群里一不小心地看到了远征攻略要看什么哈)。于是乎我扫了一遍题目就果断放弃去看视频了。

2、具体操作:

等我看完了要用的东西,也就是C++视频教程小结(3)里那些东西,再结合群里的只言片语,还是有些想法的。首先这次要建的是一个项目,里面有三个文件,可以确定的是有一个main函数的.cpp文件,至于另外两个类的文件我觉得应该是.h文件,在分文件类外定义里有类似的东西,可以模仿着在.cpp里调用它们。然后就先写出了大致的框架,各个文件各种include先来一遍,再来是mian函数,Scan类和Print类的框架。接下来就要写框架里面的东西,按照顺序看了一遍下来,感觉问题不是很大,比较复杂的也就是Scan里面的那个函数。关于Scan类里面的ToStringQueue函数,我刚开始觉得只要用一个for循环就能把数字和符号提取出来,具体来说长这样(把函数的想法单独拿出来调试):

    #include<stdlib.h>
#include<iostream>
#include<string>
#include<queue>
using namespace std; int main()
{
string input;
queue<string>q; getline(cin,input);
for(int i=0;i<input.size();i++)
{
q.push(input[i]); //把string类型的input每个位置的元素都存到队列q里面(感觉数和字符瞬间分开了啊)
cout<<input[i]<<endl; //检查传入的元素
} system("pause");
return 0;
};

结果一运行就有问题:



好像是类型不对,具体怎样也不是很清楚,然后试着把代码部分改成这样:

         string input,str;
queue<string>q; getline(cin,input);
for(int i=0;i<input.size();i++)
{
str=input[i];
q.push(str);
cout<<input[i]<<endl;
}

编译居然通过了,但是样例的运行结果长这样:



看样子我是太天真了啊,看样子要重新考虑ToStringQueue函数的实现方法了。输入的是四则运算的字符串,那么相对数字来说字符只有加减乘除和括号六个,于是我选择对字符进行特判,用来决定是否存入队列。下面是改来改去的还可以看的代码(主要部分),想法看注释就好:

                int n=0;
string input,str;
queue<string>q; getline(cin,input);
for(int i=0;i<input.size();i++) //逐个扫描input每个位置的元素
{
if(input[i] == '+'||input[i] == '-'||input[i] == '*'||input[i] == '/'||input[i] == '('||input[i] == ')')
{
if(!str.empty()) //第一个有可能是需要特判的特判字符'-',这是避免存入空串
{
q.push(str); //把特判字符之前的数字存入队列
n++; //记录队列长度
}
str=input[i];
q.push(str); //元素如果是+、-、*、/、(、)这些字符,直接存入队列
n++; //记录队列长度
str.clear(); //把str变成空串,不然会影响到数字的储存
}
else
{
str=str+input[i]; //如果是长得像数字的字符,就把它们接起来变成一个字符
}
}
for(int i=0;i<n;i++)
{
cout<<q.front()<<endl; //检查存到队列里的到底是什么
q.pop();
}

然后样例的运行结果如下:



但是我并没有高兴多久,我又随便输入了一个运算调试,结果是这样的:



重新考虑了一下发现上面的代码只适用于算式的最后是)的算式。。。所以我把部分代码改成了这样:

else
{
str=str+input[i]; //如果是长得像数字的字符,就把它们接起来
if(i==input.size()-1)
{
q.push(str);
} //如果已是最后一位,直接存入队列
}

然后就可以正确的输出最后是数字的算式了:



到这里ToStringQueue函数已经差不多了,就开始完善一些细节。我把记录队列长度的n去掉,在for循环里直接用队列的长度q.size(),就是这样:

    for(int i=0;i<q.size();i++)
{
cout<<q.front()<<endl; //检查存到队列里的到底是什么
q.pop();
}

但是结果却是这样:



我在代码里加了一句cout<<q.size()<<endl;,运行结果是这样的:



这到底是为什么。。。最后我试着把代码改成这样:

    int n=q.size();
for(int i=0;i<n;i++)
{
cout<<q.front()<<endl; //检查存到队列里的到底是什么
q.pop();
}

运行结果居然是这样的:



本着能过就好的心态,直接进入下一阶段。接下来就是数位超过十位报错,这个没什么问题,也就不细说(在代码里面是用cnt来判断的)。最后就是再push到Github上。

3、最终的代码:

  • Main.cpp
    #include<stdlib.h>
#include<iostream>
#include<string>
#include<queue>
#include"Scan.h"
#include"Print.h"
using namespace std;
    int main()
{
Scan scan;
Print print;
string input;
queue<string>q;
        getline(cin,input);
q=scan.ToStringQueue(input);
print.getStringQueue(q);
        system("pause");
return 0;
}
  • Scan.h
    #include<stdlib.h>
#include<iostream>
#include<string>
#include<queue>
using namespace std;
    class Scan
{
public:
queue<string> ToStringQueue(string input)
{
int cnt=0;
queue<string>q;
string str;
                for(int i=0;i<input.size();i++)
{
if(input[i] == '+'||input[i] == '-'||input[i] == '*'||input[i] == '/'||input[i] == '('||input[i] == ')')
{
cnt=0;
                        if(!str.empty())
{
q.push(str);
}
                        str=input[i];
q.push(str);
str.clear();
}
                    else
{
str=str+input[i];
                         if(input[i]!='.')
{
cnt++;
}
                         if(cnt==11)
{
cout<<"wrong input"<<endl;
system("pause");
}
                         if(i==input.size()-1)
{
q.push(str);
}
}
}
return q;
}
};
  • Print.h
    #include<stdlib.h>
#include<iostream>
#include<string>
#include<queue>
using namespace std;
    class Print
{
public:
void getStringQueue(queue<string>q)
{
int n=q.size();
for(int i=0;i<n;i++)
{
cout<<q.front()<<endl;
q.pop();
}
}
};

4、一些调试样例:

第三次作业之Calculator项目随笔的更多相关文章

  1. 《Coderxiaoban团队》第三次作业:团队项目的原型设计

    <XXX团队>第三次作业:团队项目的原型设计 项目 内容 这个作业属于哪个课程 任课教师博客主页链接 这个作业的要求在哪里 实验七 团队作业3:团队项目原型设计与开发 团队名称 Coder ...

  2. 《ABCD组》第三次作业:团队项目的原型设计

    <ABCD组>第三次作业:团队项目的原型设计 项目 内容 这个作业属于哪个课程 http://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https:// ...

  3. 《AlwaysRun团队》第三次作业:团队项目的原型设计

    <AlwaysRun团队>第三次作业:团队项目的原型设计 项目 内容 这个作业属于哪个课程 [任课教师博客主页链接](https://home.cnblogs.com/u/nwnu-dai ...

  4. 第三次作业— C++计算器项目的初始部分

    作业题目: C++计算器项目的初始部分 仓库 代码: Scan.h #ifndef SCAN_H #define SCAN_H #include<string> #include<i ...

  5. 面向对象课程 - 寒假第三次作业 - C++计算器项目初始部分

    C++计算器项目初始部分 零.项目源文件地址 传送门:calculator 一.项目信息相关: 项目:Calculator 版本:1.0 日期:2016.2.16 实现: 基本的操作界面 对四则运算表 ...

  6. 《Hello--world团队》第三次作业:团队项目的原型设计

    项目 内容 这个作业属于哪个课程 2016级计算机科学与工程学院软件工程(西北师范大学) 这个作业的要求在哪里 实验七 团队作业3:团队项目原型设计与开发 团队名称 <hello--world团 ...

  7. 《Exception团队》第三次作业:团队项目的原型设计

    一.项目基本介绍 项目 内容 这个作业属于哪个课程 任课教师博客主页链接 这个作业的要求在哪里 作业链接地址 团队名称 Exception 作业学习目标 学习原型设计过程以及工具的使用 二.原型设计细 ...

  8. 《BUG创造队》第三次作业:团队项目原型设计与开发

    项目 内容 这个作业属于哪个课程 2016级软件工程 这个作业的要求在哪里 实验六 团队作业3:团队项目原型设计与开发 团队名称 BUG创造队 作业学习目标 ①掌握软件原型开发技术:②学会使用软件原型 ...

  9. 《Miracle-House团队》第三次作业:团队项目的原型设计与开发

    一.实验目的与要求 1.掌握软件原型开发技术 2.学习使用软件原型开发工具 二.实验内容与步骤 1.开发工具: 使用的工具:墨刀(APP端开发原型) 工具简介: 墨刀(MockingBot)是一款简单 ...

随机推荐

  1. Asp.Net判断字符是否为汉字的方法大全

    判断一个字符是不是汉字通常有三种方法: 第一种用 ASCII 码判断,缺点:把全角逗号“,”当汉字处理 第二种用汉字的 UNICODE 编码范围判 断, 第三种用正则表达式判断 1.用ASCII码判断 ...

  2. setTimeOut() 和 setTimeInterval()

    setTimeOut()は.指定された時間「待ってから」指定された動作を行う関数です.setTimeOut():等待指定时间,执行指定方法. setTimeInterval()は.指定された時間「間隔 ...

  3. [反汇编练习] 160个CrackMe之026

    [反汇编练习] 160个CrackMe之026. 本系列文章的目的是从一个没有任何经验的新手的角度(其实就是我自己),一步步尝试将160个CrackMe全部破解,如果可以,通过任何方式写出一个类似于注 ...

  4. ecshop 改变sitemap.xml的位置

    大家知道ECSHOP默认的sitemap.xml文件是放置在data文件夹中的,但是这不利于GOOGLE的抓取.我们必须把sitemap.xml文件放置在根目录下 在admin/sitemap.php ...

  5. HDU 产生冠军 2094

    解题思路:这题重在分析,可能你知道的越多,这题想得越多,什么并查集,什么有向图等. 事实是,我们会发现,只要找到一个,并且仅有一个的入度为0的点,说明可以找出   冠军.若入度为0的点一个都没有,说明 ...

  6. Heritrix源码分析(一) 包介绍(转)

    本博客属原创文章,欢迎转载!但转载请务必注明出处:http://guoyunsky.iteye.com/blog/613249 本博客已迁移到本人独立博客: http://www.yun5u.com/ ...

  7. centos6 下安装xfce+vnc

    CentOS 安装图形界面的过程,简单记录一下.这里提供了两种图形界面的安装,分别是CentOS自带的gnome桌面及轻巧的xfce.据测试,我的精简版CentOS 6 64位系统安装gnome需要下 ...

  8. 谷歌浏览器如何设置可以解决Ajax跨域问题?

    Ajax本身是不支持跨域的,跨域问题其实很简单,通过浏览器的相应设置可以完成两个不同的服务器或两个不同服务下的项目互相访问.希望大家给予评价及投票. 方法/步骤   首先谷歌快捷方式上右击,在下拉列表 ...

  9. vsftpd2.3.2安装、配置详解

    一.vsftpd 简介     Vsftpd是一个基于GPL发布的类UNIX系统的ftp服务器软件.其全称是Very Secure FTP Deamon,在安全性.速度和稳定性都有着不俗的表现.在安全 ...

  10. zz github配置

    First : 安装:ubuntu 下,终端输入命令: sudo apt-get install git-core git-gui git-doc Next : 设置SSH Key 检查是否已经有SS ...