DS实验题 最大最小
题目:
算法设计:
计算最小值算法:
设置一个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实验题 最大最小的更多相关文章
- DS实验题 融合软泥怪-2 Heap实现
题目和STL实现:DS实验题 融合软泥怪-1 用堆实现优先队列 引言和堆的介绍摘自:Priority Queue(Heaps)--优先队列(堆) 引言: 优先队列是一个至少能够提供插入(Insert) ...
- DS实验题 Old_Driver UnionFindSet结构 指针实现邻接表存储
题目见前文:DS实验题 Old_Driver UnionFindSet结构 这里使用邻接表存储敌人之间的关系,邻接表用指针实现: // // main.cpp // Old_Driver3 // // ...
- DS实验题 Dijkstra算法
参考:Dijkstra算法 数据结构来到了图论这一章节,网络中的路由算法基本都和图论相关.于是在拿到DS的实验题的时候,决定看下久负盛名的Dijkstra算法. Dijkstra的经典应用是开放最短路 ...
- DS实验题 sights
算法与数据结构实验题 6.3 sights ★实验任务 美丽的小风姑娘打算去旅游散心,她走进了一座山,发现这座山有 n 个景点, 由于山路难修,所以施工队只修了最少条的路,来保证 n 个景点联通,娇弱 ...
- DS实验题 order
算法与数据结构 实验题 6.4 order ★实验任务 给出一棵二叉树的中序遍历和每个节点的父节点,求这棵二叉树的先序和后序遍历. ★数据输入 输入第一行为一个正整数n表示二叉树的节点数目,节点编号从 ...
- DS实验题 Inversion
题目: 解题过程: 第一次做这题的时候,很自然的想到了冒泡和选择,我交的代码是用选择写的.基本全WA(摊手). 贴上第一次的代码: // // main.cpp // sequenceschange ...
- DS实验题 融合软泥怪-1
题目 思路 很容易想到第一种做法,用Huffman算法,从森林中找出两个值最小的节点,合并再加入森林,在这个过程中不断记录. 但是每一次需要sort一遍,将最小的两个值节点置于头两个节点,最坏情况下复 ...
- DS实验题 Order 已知父节点和中序遍历求前、后序
题目: 思路: 这题是比较典型的树的遍历问题,思路就是将中序遍历作为位置的判断依据,假设有个节点A和它的父亲Afa,那么如果A和Afa的顺序在中序遍历中是先A后Afa,则A是Afa的左儿子,否则是右儿 ...
- DS实验题 Missile
题目: 提示:并没有精度问题. 原题 NOIP2010 导弹拦截 思路 设源点为A(x1, y1)和B(x2, y2). 第一步,用结构体存节点,包括以下元素: 1.横坐标x 2.纵坐标y 3.节点和 ...
随机推荐
- JDK JRE 区别
JDK 包含了编译器,比如让.java编译成.classs文件. JRE =Java Runtime Environment j是一些比如一些split函数需要的包,都在里面,基本的运行环境都在JR ...
- 使用webstorm操作git
0. 前言 在上一篇文章中,讲述了使用webstorm去调试node程序,最近研究了一下如何使用webstorm去操作git. 对于git的使用,大家的使用方式均有不同,最王道的方式非命令行莫属,基于 ...
- 二、JavaScript语言--JS基础--JavaScript进阶篇--数组
1.什么事数组 我们知道变量用来存储数据,一个变量只能存储一个内容.假设你想存储10个人的姓名或者存储20个人的数学成绩,就需要10个或20个变量来存储,如果需要存储更多数据,那就会变的更麻烦.我们用 ...
- 使yum保留下载的rpm包
[root@14LN yum]# egrep 'cachedir|keepcache' /etc/yum.conf #cachedir=/var/cache/yum/$basearch/$releas ...
- WIN7里为什么没有TELNET,怎么添加
打开控制面板,打开程序和功能,看到左边有个“打开或关闭Windows功能 ,打开找到telnet客户端,把这2项都勾选上,然后确定就可以了 注意,如果只要telnet别人的话,就选telnet客户端. ...
- oracle 10g 学习之oracle管理(3)
怎样将预先写好的sql脚本执行? select * from employees;→107条记录 利用 Oracle 企业管理器连接数据库服务器 点击打开以下界面: 此时已经连接成功了 用 Oracl ...
- Java判断文件编码格式
转自:http://blog.csdn.net/zhangzh332/article/details/6719025 一般情况下我们遇到的文件编码格式为GBK或者UTF-8.由于中文Windows默认 ...
- 分享一下spark streaming与flume集成的scala代码。
文章来自:http://www.cnblogs.com/hark0623/p/4172462.html 转发请注明 object LogicHandle { def main(args: Array ...
- SU Demos-03T-F Analysis-01Sugabor
先看readme, 运行结果,
- Unity3d中SendMessage 用法简单笔记
Message相关有3条指令:SendMessage ("函数名",参数,SendMessageOptions) //GameObject自身的ScriptBroadcastMes ...
