【ZZNU-oj-2116:人间不值得】(1亿以内的货币拼音转数值求折扣价原价)--hash+String大法好+字符串处理+超大暴力模拟题
题目描述
家缠万贯来几时,我今停杯一问之。人攀暴富不可得,贫穷却与人相随。何以解忧,唯有暴富。spring做梦都想暴富,但是又苦于囊中羞涩。每次消费都会精打细算,所以每次消费都会记在小本本上。可惜spring是个汉字盲,你能帮他来完成汉字拼音转化为数字么。spring每次的消费都是一行格式表示分别为原价(或折扣价) 价格 折扣度 的拼音形式展开。 拼音中不包含汉字“两”的拼音,只有汉字“二”的拼音。
输入
输入一行 共有三个字符串,分别代表 原价(折扣价)拼音 和 价格拼音 以及 折扣度拼音,表示spring每次的消费。
其中 价格拼音转化成数字不超过1亿元,价格拼音的组成符合我们日常的叫法,如5010 五千零十元。折扣度拼音转化成汉字将不多于五个汉字,如六七折,一二三四折等,不存在零折,但可能存在零一折等。数字都是正整数。
输出
来帮他完成汉字拼音转化,spring需要你。求出 原价为多少钱,以及折扣价为多少,两者中间保留空格,保留两位有效数字。占一行。
样例输入
yuanjia erbaiyuan wuzhe
zhekoujia yibaiyuan wuzhe
样例输出
200.00 100.00
200.00 100.00
提示
思路:1、构造拼音到数值的has表,处理冲突的“qi”和“qian”,“ba”和“bai”。
2、String类的find()函数是个好东西,直接找到对应的子字符串,然后换成“Qi”和“qIan”,“Ba”和“bAi”
3.int d[]表示偏移量数组,find(“子字符串”)返回-1表示没有结果,其余表示可以找到,然后向后偏移d【i】位,d[i]其实等于当前子字符串的长度;还有在偏移一段后,要将刚刚找到的字符串抹掉——全部变成“*******”号!
4、其余的问题,慢慢调试,建议在关键循环中加上printf调试!
5、删掉末尾的 yuan, s.erase(x,4); 特判1亿元等等细节方便解决问题!
6、尽情暴力即可,相信自己,问题规模不大,没有简单的方法,只管暴力!所谓“能力”,就是这么硬着发麻的头皮一步一步地锻炼出来的!
题解:(建议,好的学习方法是借鉴下别人的思路,自己进行大胆尝试解决,能自己跑多远就跑多远;出现问题再回去找找,一味地照搬没多大意义)
#include <iostream>
#include<stdio.h>
#include<string.h>
#include<string>
#include<algorithm>
#define ll long long
using namespace std;
#define N 100
char arr[][]= {"ling","yi","er","san","si","wu","liu","Qi","Ba","jiu",
"shi","bAi","qIan","wan"
}; //0~9 + 10~13
int has[]= {,,,,,,,,,,,,,,}; //has[14]为亿
int d[]= {,,,,, ,,,,, ,,,}; //偏移量
int solve(char sn[])
{ string s(sn);
int x,len=s.length(); while(x=s.find("qi"),x>=&&x<len) //替换qi 和 qian
{
if(x+<=len-&&s[x+]!='a')
s[x]='Q';
else if(x+>=len)
s[x]='Q';
else
s[x+]='I';
}
while(x=s.find("ba"),x>=&&x<len) //替换Ba 和 bAi
{
if(x+<=len-&&s[x+]!='i')
s[x]='B';
else if(x+>=len)
s[x]='B';
else
s[x+]='A';
}
x=s.find("yuan"); //删掉末尾的 yuan
if(x>=&&x<len)
s.erase(x,);
// cout<<s<<" ~~删减yuan后~"<<endl;
//特判1亿元
x=s.find("yiyi");
if(x>=&&x<len)
return has[]; x=;
len=s.length();
int sum=,ss=;
while(x<len)
{
int i=;//代表是第几个汉字
while(i<&&s.find(arr[i])!=x)
i++;
if(i==) //出现错误,反馈error
{
cout<<"error"<<endl;
break;
}
if(i>=&&i<=)
{
if(ss==)sum+=has[i];
ss*=has[i],sum+=ss,ss=;
}
else if(i==)
sum+=ss,ss=,sum*=has[];
else if(i>)
ss=has[i]; for(int j=x; j<x+d[i]; j++) //走一步删一步
s[j]='*';
x+=d[i];
// printf("***i=%d x=%d ss=%d sum=%d\n",i,x,ss,sum);
}
return sum+ss;
}
double get_op(char sn[])
{
string s(sn);
int x,len=s.length();
double op=0.0;
while(x=s.find("qi"),x>=&&x<len) //替换qi 和 qian
{
if(x+<=len-&&s[x+]!='a')
s[x]='Q';
else if(x+>=len)
s[x]='Q';
else
s[x+]='I';
}
while(x=s.find("ba"),x>=&&x<len) //替换Ba 和 bAi
{
if(x+<=len-&&s[x+]!='i')
s[x]='B';
else if(x+>=len)
s[x]='B';
else
s[x+]='A';
}
int sum=,ss=;
x=s.find("zhe"); //删掉末尾的 zhe
if(x>=&&x<len)
s.erase(x,);
len=s.length();
x=;
int cnt=;
while(x<len)
{
int i=;//代表是第几个个汉字
while(i<&&s.find(arr[i])!=x)
i++;
if(i==)
{
cout<<"error"<<endl;
break;
}
op=op*10.0+has[i];
cnt++;
for(int j=x; j<x+d[i]; j++) //走一步删一步
s[j]='*';
x+=d[i];
// printf("***i=%d x=%d op=%lf \n",i,x,op);
}
while(cnt--)
op=op*0.1;
return op;
}
int main()
{
char s1[],s2[],s3[];
while(scanf("%s%s%s",s1,s2,s3)!=EOF)
{
if(strcmp(s1,"yuanjia")==) //给的是原价和折扣op
{
double cost,discost,op; //原价为cost,折扣后的价为discost!
cost=solve(s2)*1.0;
op=get_op(s3);//printf("op*****%.6lf\n",op); discost=cost*op;
printf("%.2lf %.2lf\n",cost,discost);
}
else //给的是折扣价和 折扣op
{
double cost,discost,op;
discost=solve(s2);
op=get_op(s3);//printf("op*****%.6lf\n",op);
cost=discost/op;
printf("%.2lf %.2lf\n",cost,discost);
}
// printf("****%.4lf\n",1.11/10.00);
} return ;
}
(可以模仿着写写,花一天时间搞定也是值得的!)
【ZZNU-oj-2116:人间不值得】(1亿以内的货币拼音转数值求折扣价原价)--hash+String大法好+字符串处理+超大暴力模拟题的更多相关文章
- 【入门OJ】2003: [Noip模拟题]寻找羔羊
这里可以复制样例: 样例输入: agnusbgnus 样例输出: 6 这里是链接:[入门OJ]2003: [Noip模拟题]寻找羔羊 这里是题解: 题目是求子串个数,且要求简单去重. 对于一个例子(a ...
- ZZNU - OJ - 2080 : A+B or A-B【暴力枚举】
2080 : A+B or A-B(点击左侧标题进入zznu原题页面) 时间限制:1 Sec 内存限制:0 MiB提交:8 答案正确:3 提交 状态 讨论区 题目描述 Give you three s ...
- 用vector与bitset分别创建1亿以内的素数表,比较快慢
vector容器: 代码如下: #include<iostream>#include<vector>#include<ctime>using namespace s ...
- 4190. Prime Palindromes 一亿以内的质数回文数
Description The number 151 is a prime palindrome because it is both a prime number and a palindrome ...
- SDUT OJ 数据结构实验之二叉树八:(中序后序)求二叉树的深度
数据结构实验之二叉树八:(中序后序)求二叉树的深度 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Probl ...
- 楼天城楼教主的acm心路历程(作为励志用)
楼主个人博客:小杰博客 利用假期空暇之时,将这几年GCJ,ACM,TopCoder 參加的一些重要比赛作个 回顾.昨天是GCJ2006 的回顾,今天时间上更早一些吧,我如今还清晰记得3 年 前,我刚刚 ...
- 【转】楼天城楼教主的acm心路历程(作为励志用)
利用假期空闲之时,将这几年GCJ,ACM,TopCoder 参加的一些重要比赛作个回顾.昨天是GCJ2006 的回忆,今天时间上更早一些吧,我现在还清晰记得3 年前,我刚刚参加ACM 时参加北京赛区2 ...
- 剪辑的楼天城的ACM之路
楼天城楼教主的acm心路历程(剪辑) 利用假期空闲之时,将这几年GCJ,ACM,TopCoder 参加的一些重要比赛作个回顾.昨天是GCJ2006 的回忆,今天时间上更早一些吧,我现在还清晰记得3 年 ...
- 楼塔当天领袖acm心理(作为励志使用)
楼主个人博客:吉尔博客 假期空闲的时候使用.这些年来GCJ.ACM,TopCoder 的一个号码的一重要的比赛的参与 回顾.GCJ2006 的回顾,今天时间上更早一些吧,我如今还清晰记得3 年 前.我 ...
随机推荐
- vue+element-ui动态生成多级表头,并且将有相同字段下不同子元素合并为同一个
element表头要多层生成,下一级表头数据源必须是当前表头的子一级,这样一层一层嵌套可以生成多层表头: 要把数据处理成这种类型的数据 var arr = []; for (var key in ob ...
- [转帖]详解JVM内存布局及GC原理,值得收藏
概述 https://www.toutiao.com/i6731345429574713868/ java发展历史上出现过很多垃圾回收器,各有各的适应场景,不仅仅是开发,作为运维也需要对这方面有一定的 ...
- Fiddler之打断点
1..Fiddler可以修改以下请求 --Fiddler设置断点,可以修改HTTP请求头信息,如修改Cookie,User-Agent等 --可以修改请求数据,突破表单限制,提交任意数字,如充值最小1 ...
- 第6章:LeetCode--数组(冒泡排序、快速排序)
11. Container With Most Water class Solution { public: int maxArea(vector<int>& height) { ...
- MySQL的sql语言分类DML、DQL、DDL、DCL
SQL语言一共分为4大类:数据定义语言DDL,数据操纵语言DML,数据查询语言DQL,数据控制语言DCL 1.数据定义语言DDL(Data Definition Language) 对象: 数据库和表 ...
- gin mongodb restful api设计: 动态的patch接口
目录 什么是Patch? Patch方法可以用来更新资源的一个组成部分 什么时候使用Patch? 当你仅需更新资源的某一项,即不完全也不幂等 那当我们的模型在数据库中几乎每个字段都可能会遇到改变的时候 ...
- package.json 版本解释
指定版本:比如1.2.2,遵循“大版本.次要版本.小版本”的格式规定,安装时只安装指定版本.波浪号(tilde)+ 指定版本:比如~1.2.2,表示安装1.2.x的最新版本(不低于1.2.2),但是不 ...
- Maven配置、使用
一:什么是Maven Maven项目对象模型(POM),可以通过一小段描述信息来管理项目的构建,报告和文档的项目管理工具软件. Maven提供了开发人员构建一个完整的生命周期框架,开发人员可以自动完成 ...
- sql 计算奇数还是偶数
& 运算符来判断奇数还是偶数 sql判断奇数还是偶数 3&1 返回 1 2&1 返回0 0&1 返回 0
- ant Windows下环境变量配置 安装 编译
下载 官网:[http://ant.apache.org/] 其他版本:[http://archive.apache.org/dist/ant/binaries/] 点击这个进入下载页面 Window ...