题目:

算法设计:

计算最小值算法:

设置一个flag,flag为1的时候代表遇到*号;

遇到数字时:

flag为0进栈;

flag为1的时候,从栈顶提出一个元素和当前元素运算,结果进栈

最后对栈进行加法运算,得到结果,mod。

计算最大值算法:

设置一个flag,flag为1的时候代表遇到+号;

设置一个累加器pt;

遇到数字时

1.flag为0进栈;

2.flag为1的时候,需要对之前flag的状态进行判断:

flag_pre若为1,更新累加器;

flag_pre若为0,从栈顶压出一个元素,更新累加器;

遇到乘号时

1.flag为0,continue;

2.flag为1,将flag置0,累加器结果进栈,累加器置0;

遍历字符串结束时,特判累加器是否为0,不为0进栈;

最后对栈进行乘法运算,得到结果,mod。

代码:

//
// main.cpp
// 最大最小
//
// Created by wasdns on 16/11/10.
// Copyright © 2016年 wasdns. All rights reserved.
// #include <iostream>
#include <cstdio>
#include <string>
#include <string.h>
#include <stack>
using namespace std; #define modn 870764322 char str[505]; //字符串 /*
计算最小值算法:
设置一个flag,flag为1的时候代表遇到*号; 遇到数字时:
flag为0进栈;
flag为1的时候,从栈顶提出一个元素和当前元素运算,结果进栈 最后对栈进行加法运算,得到结果,mod。
*/ int Nomalcal()
{
stack<int> ins; int i, cal_result = 0; int flag = 0; for (i = 0; i < strlen(str); i++)
{
if (str[i] == '(' || str[i] == ')') continue; //遇到括号略过 if (str[i] >= '0' && str[i] <= '9') //遇到数字
{
int pt = str[i] - '0'; if (flag == 1) { //flag=1 int pre = ins.top();
ins.pop(); int64_t temp = pt; //为防止溢出,进行转换
temp *= pre;
temp %= modn; pt = (int)temp; flag = 0;
} ins.push(pt);
} else if (str[i] == '*') { //遇到乘号 flag = 1; continue;
} else continue; //遇到加号
} while (!ins.empty()) { //计算结果 cal_result += ins.top();
cal_result %= modn; ins.pop();
} return cal_result;
} /*
计算最大值算法: 设置一个flag,flag为1的时候代表遇到+号;
设置一个累加器pt; 遇到数字时
1.flag为0进栈;
2.flag为1的时候,需要对之前flag的状态进行判断:
flag_pre若为1,更新累加器;
flag_pre若为0,从栈顶压出一个元素,更新累加器; 遇到乘号时
1.flag为0,continue;
2.flag为1,将flag置0,累加器结果进栈,累加器置0; 遍历字符串结束时,特判累加器是否为0,不为0进栈; 最后对栈进行乘法运算,得到结果,mod。
*/ int maxcal()
{
stack<int> ins; int i, cal_result = 1; //注意,结果初始置1 int flag = 0; int pt = 0; for (i = 0; i < strlen(str); i++)
{
if (str[i] == '(' || str[i] == ')') continue; //遇到括号 if (str[i] >= '0' && str[i] <= '9') //遇到数字
{
if (flag == 1) { //1.flag=1 pt += (str[i] - '0'); } else { //2.flag=0 pt = (str[i] - '0'); ins.push(pt); pt = 0; } continue;
} else if (str[i] == '*') { //遇到乘号 if (flag == 1) { //flag=1时 flag = 0; ins.push(pt); pt = 0; } continue;
} else { //遇到加号时 if (flag == 0) { int pre = ins.top();
ins.pop(); pt += pre;
} flag = 1; continue;
}
} if (pt != 0) { //特判
ins.push(pt);
} int64_t temp = 1; while (!ins.empty()) { //计算结果,防止溢出 temp *= (ins.top());
temp %= modn; ins.pop();
} cal_result = (int)temp; return cal_result;
} int main()
{
scanf("%s", str); getchar(); cout << maxcal() << endl; cout << Nomalcal() << endl; return 0;
}

结果:

小结:

上面的代码交上去是编译错误,需要把里面的int64_t类型换成__int64

注意:防止溢出;因此在计算结果的时候(一般在乘法的地方),进行一次类型的转换,用int64存储,取mod之后再转为int。

2016/11/10

DS实验题 最大最小的更多相关文章

  1. DS实验题 融合软泥怪-2 Heap实现

    题目和STL实现:DS实验题 融合软泥怪-1 用堆实现优先队列 引言和堆的介绍摘自:Priority Queue(Heaps)--优先队列(堆) 引言: 优先队列是一个至少能够提供插入(Insert) ...

  2. DS实验题 Old_Driver UnionFindSet结构 指针实现邻接表存储

    题目见前文:DS实验题 Old_Driver UnionFindSet结构 这里使用邻接表存储敌人之间的关系,邻接表用指针实现: // // main.cpp // Old_Driver3 // // ...

  3. DS实验题 Dijkstra算法

    参考:Dijkstra算法 数据结构来到了图论这一章节,网络中的路由算法基本都和图论相关.于是在拿到DS的实验题的时候,决定看下久负盛名的Dijkstra算法. Dijkstra的经典应用是开放最短路 ...

  4. DS实验题 sights

    算法与数据结构实验题 6.3 sights ★实验任务 美丽的小风姑娘打算去旅游散心,她走进了一座山,发现这座山有 n 个景点, 由于山路难修,所以施工队只修了最少条的路,来保证 n 个景点联通,娇弱 ...

  5. DS实验题 order

    算法与数据结构 实验题 6.4 order ★实验任务 给出一棵二叉树的中序遍历和每个节点的父节点,求这棵二叉树的先序和后序遍历. ★数据输入 输入第一行为一个正整数n表示二叉树的节点数目,节点编号从 ...

  6. DS实验题 Inversion

    题目: 解题过程: 第一次做这题的时候,很自然的想到了冒泡和选择,我交的代码是用选择写的.基本全WA(摊手). 贴上第一次的代码: // // main.cpp // sequenceschange ...

  7. DS实验题 融合软泥怪-1

    题目 思路 很容易想到第一种做法,用Huffman算法,从森林中找出两个值最小的节点,合并再加入森林,在这个过程中不断记录. 但是每一次需要sort一遍,将最小的两个值节点置于头两个节点,最坏情况下复 ...

  8. DS实验题 Order 已知父节点和中序遍历求前、后序

    题目: 思路: 这题是比较典型的树的遍历问题,思路就是将中序遍历作为位置的判断依据,假设有个节点A和它的父亲Afa,那么如果A和Afa的顺序在中序遍历中是先A后Afa,则A是Afa的左儿子,否则是右儿 ...

  9. DS实验题 Missile

    题目: 提示:并没有精度问题. 原题 NOIP2010 导弹拦截 思路 设源点为A(x1, y1)和B(x2, y2). 第一步,用结构体存节点,包括以下元素: 1.横坐标x 2.纵坐标y 3.节点和 ...

随机推荐

  1. Nginx与Redis解决高并发问题

    原文链接:http://bbs.phpchina.com/forum.php?mod=viewthread&tid=229629 第一版产品采用的是Jquery,Nginx,PHP(CI框架) ...

  2. CodeIgniter - 数据库的增删改查

    数据库操作无非是CRUD,用非装逼的语言来说就是增删改查.也许这一节会讲的很泛泛,或者很多人看不懂,没关系,大致的看看,知道是这么回事就好,继续往后看,后面会讲实例,这些枯燥而又抽象的东西可以先跳过, ...

  3. linux tricks 之 BUILD_BUG_ON_ZERO.

    ------------------------------------------- 本文系作者原创, 欢迎大家转载! 转载请注明出处:netwalker.blog.chinaunix.net -- ...

  4. mysql错误:“ Every derived table must have its own alias”(每个派生出来的表都必须有一个自己的别名)

    自我感悟: 由此可以延伸,我们得到一个结果集,可以通过as XXX的方式,把结果集给当作一张表来用,以实现子查询: 一般在多表查询时,会出现此错误. 因为,进行嵌套查询的时候子查询出来的的结果是作为一 ...

  5. codevs 2924 数独

     数独挑战 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codevs.cn/problem/2924/ Description “芬兰数学家因 ...

  6. SU Demos-03T-F Analysis-01Sugabor

    先看readme, 运行结果,

  7. 模拟 2013年山东省赛 J Contest Print Server

    题目传送门 /* 题意:每支队伍需求打印机打印n张纸,当打印纸数累计到s时,打印机崩溃,打印出当前打印的纸数,s更新为(s*x+y)%mod 累计数清空为0,重新累计 模拟简单题:关键看懂题意 注意: ...

  8. Oracle 使用小计(3)

      1.出错处理 ORA-00911: invalid character. 这是因为在语句末尾加上了";"的缘故,去掉";"SQL就可以执行了~ (这与SQL ...

  9. C#:代表(delegate)和事件(event)

    代表(delegate): 它是C#语言里面的函数指针,代表可以指向某一个函数,在运行的时候调用这个函数的实现.下面来看看它的实现步骤: 声明一个delegate对象. 实现和delegate具有相同 ...

  10. OGRE: "OgreOverlaySystem.h": No such file or directory

    这两天学习OGRE,遇到"OgreOverlaySystem.h": No such file or directory的错误. 这是由于OGRE提供的例子过老,和SDK版本不一致 ...