Description

高中物理老师总认为给学生文本形式的问题比给纯计算形式的问题要求更高。毕竟,学生首先得阅读和理解问题。

因此,他们描述一个问题不像”U=10V,I=5A,P=?”,而是”有一个含有U=10V 的电池组和灯泡的电路。现在有I=5A 的电流通过灯泡,问灯泡产生的功率是多少?”

然而,大多数学生并不在乎题目文本。他们只是从文本中提取出:U=10V,I=5A。然后他们想:”我知道哪个公式呢?哦,对了,P=UI。因此P=10V5A=50W。搞定。”

现在,我们只考虑一个P-U-I 类型的问题。即功率,电压和电流中的两个告诉你,你要求剩下那个。

你的任务是写一个程序,从输入文件中读入一些文本问题,然后要你计算剩下那个的值。

Input

第一行为一个正整数,表示数据组数。

每组数据包含一行,为一个包含两个数据区和一些任意单词的字符串。一个数据区具有如下形式:I=xA,U=xV 或P=xW,x 是一个实数。在A,V,W 之前有可能出现前缀m(毫, 千分之一),k(千),M(兆,百万)。以下是几点关于输入的说明:

  1. 等号(‘=’)只会在数据区出现,不会在其他地方出现;

  2. 数据区内没有空格字符;

  3. P 和U,P 和I,或U 和I 中的一个会给出;

文本问题长度不超过255,且数据组数不超过3 组。

Output

对于每组数据输出一行,形式如:P=xW,I=xA 或U=xV(取决于输入数据),x 为一个实数,保留两位小数。在A,V,W 前不要出现前缀。

Sample Input

3
If the voltage is U=200V and the current is I=4.5A, which power is generated?
A light-bulb yields P=100W and the voltage is U=220V. Compute the current, please.
bla bla bla lightning strike I=2A bla bla bla P=2.5MW bla bla voltage?

Sample Output

P=900.00W
I=0.45A
U=1250000.00V 题意:模拟题,但是要注意的是如何读入字符串文本,而且要注意的是这个数可能是小数,而且后缀的单位也不一定,需要统一一下。具体的细节可以看下代码。
#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <math.h>
#include <set>
using namespace std;
const int maxn=;
int n,x,temp;
string s;
int main()
{
scanf("%d ",&n);//注意要在后加一个空格,不然getline在读入下一行的时候,会把那个换行字符读进去
while(n--)
{
double P=,U=,I=;
getline(cin,s);
int len=s.length();
// cout<<len<<endl;
for(int i=;i<len;i++)
{
if(s[i]=='=')
{
if(s[i-]=='U')
{
int j=i+;
int pos=;
while(j<len)//找到这个数到哪结束,然后方便我们把其转换为数字
{
if(s[j]>=''&&s[j]<='')
{
j++;
}
else if(s[j]=='.')//确定这个数是否为小数,记录下小数点的位置
{
pos=j;
j++;
}
else
break;
}
// cout<<j<<endl;
int cnt=;
if(pos==)//是整数
{
for(int k=j-;k>i;k--)
{
U+=((s[k]-'')*(pow(,cnt++)));
}
}
else
{
for(int k=pos-;k>i;k--)
U+=((s[k]-'')*(pow(,cnt++)));
cnt=;//cnt要重置一下
for(int k=pos+;k<j;k++)
U+=((s[k]-'')/(pow(,cnt++)));
}
if(s[j]=='m')//判断后面的单位问题,后面同理操作。
U/=;
else if(s[j]=='M')
U*=;
else if(s[j]=='k')
U*=;
// cout<<U<<endl;
} if(s[i-]=='P')
{
int j=i+;int pos=;
while(j<len)
{
if(s[j]>=''&&s[j]<='')
{
j++;
}
else if(s[j]=='.')
{
pos=j;
j++;
}
else
break;
}
int cnt=;
if(pos==)
{
for(int k=j-;k>i;k--)
{
P+=((s[k]-'')*(pow(,cnt++)));
}
}
else
{
for(int k=pos-;k>i;k--)
P+=((s[k]-'')*(pow(,cnt++)));
cnt=;
for(int k=pos+;k<j;k++)
P+=((s[k]-'')/(pow(,cnt++)));
}
if(s[j]=='m')
P/=;
else if(s[j]=='M')
P*=;
else if(s[j]=='k')
P*=;
// cout<<P<<endl;
}
if(s[i-]=='I')
{
int j=i+;
int pos=;
while(j<len)
{
if(s[j]>=''&&s[j]<='')
{
j++;
}
else if(s[j]=='.')
{
pos=j;
j++;
}
else
break;
}
int cnt=;
if(pos==)
{
for(int k=j-;k>i;k--)
{
I+=((s[k]-'')*(pow(,cnt++)));
}
}
else
{
for(int k=pos-;k>i;k--)
I+=((s[k]-'')*(pow(,cnt++)));
cnt=;
for(int k=pos+;k<j;k++)
I+=((s[k]-'')/(pow(,cnt++)));
}
if(s[j]=='m')
I/=;
else if(s[j]=='M')
I*=;
else if(s[j]=='k')
I*=;
// cout<<I<<endl;
}
}
}
if(P==)
{
printf("P=%.2fW\n",U*I);
}
else if(U==)
{
printf("U=%.2fV\n",P/I);
}
else
{
printf("I=%.2fA\n",P/U);
}
}
return ;
} /**********************************************************************
Problem: 2213
User: therang
Language: C++
Result: AC
Time:0 ms
Memory:2212 kb
**********************************************************************/

CSU 2018年12月月赛 A 2213: Physics Exam的更多相关文章

  1. CSU 2018年12月月赛 B 2214: Sequence Magic

    Description 有一个1到N的自然数序列1,2,3,...,N-1,N. 我们对它进行M次操作,每次操作将其中连续的一段区间 [Ai,Bi][Ai,Bi] (即第Ai个元素到第Bi个元素之间的 ...

  2. CSU 2018年12月月赛 H(2220): Godsend

    Description Leha somehow found an array consisting of n integers. Looking at it, he came up with a t ...

  3. CSU 2018年12月月赛 G(2219): Coin

    Description 有这样一个众所周知的问题: 你面前有7个硬币,其中有一个劣质的(它比正常的硬币轻一点点),你有一个天平,问需要你需要使用天平多少次能保证找到那个劣质的硬币. 众所周知的算法是: ...

  4. CSU 2018年12月月赛 F(2218): Finding prime numbers

    Description xrdog has a number set. There are 95 numbers in this set. They all have something in com ...

  5. CSU 2018年12月月赛 D 2216 : Words Transformation

    Description There are n words, you have to turn them into plural form. If a singular noun ends with ...

  6. 2018年12月8日广州.NET微软技术俱乐部活动总结

    吕毅写了一篇活动总结,写得很好!原文地址是:https://blog.walterlv.com/post/december-event-microsoft-technology-salon.html ...

  7. [2018-11-27]2018年12月1日宁波dotnet社区线下活动

    离上次活动,转眼又过了一个月,幸得各路大神支持,于本周六(12月1日),宁波dotnet社区的线下分享活动又来啦! 活动嘉宾及主题 董斌辉 2015-2019年微软全球最有价值专家(.NET方向) 2 ...

  8. CodePlus2017 12月月赛 div2可做题2

    11月的月赛错过了,来打12月月赛,由于很(zi)想(ji)拿(tai)衣(ruo)服(la),所以去打div2. T1是一个sb模拟,但是机房全卡死在这道语文题上了,基本上弄了一个半小时,T2可以秒 ...

  9. web前端开发2018年12月找工作总结

    2018年的冬天额外的冷,由内致外... 作为一名刚刚踏入社会的实习生,可谓是狠狠的体验了一把什么叫社会(同时也感叹父母赚钱真的很不容易) 前几天看见这样一句话"如果你不知道社会的辛苦,要么 ...

随机推荐

  1. 06_传智播客iOS视频教程_源文件后缀名和main函数

    OC与C语言的不同. 把OC程序运行起来,CPU只会找main函数.并且只会执行main函数当中的代码.当main函数的代码执行完毕之后这个程序就自动结束掉了. main函数的参数是可以让我们在运行程 ...

  2. python 匿名函数 lambda

    一.lambda使用语法: 关键字lambda表示匿名函数,冒号前面的x表示函数参数,冒号后面只能有一个表达式,不用写return,返回值就是该表达式的结果. >>> list(ma ...

  3. bzoj 1072: [SCOI2007]排列perm【状压dp】

    先写了个next_permutation结果T了,于是开始写状压 设f[s][i]为选取状态为s,选的数模d为i的方案数,去重的话直接除以每个数字的出现次数的阶乘即可 #include<iost ...

  4. HDU 5558 后缀数组

    思路: 这是一个错误的思路, 因为数据水才过= = 首先求出来后缀数组 把rank插到set里 每回差i两边离i近的rank值,更新 如果LCP相同,暴力左(右)继续更新sa的最小值 //By Sir ...

  5. bzoj1572 [Usaco2009 Open]工作安排Job【贪心 堆】

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1572 尽管这一题没有看题解,但是耗时还是比本应耗费的时间要长,所以还是写一下,以提升经验 这 ...

  6. C#委托的用法 在C#中我想在一个方法中调用另一个按钮的事件,怎样来实现?

    最开始我也不清楚,后来我是这样想了. 1.事件和委托不是一个概念,你如果是调用control的事件,可以直接在其对应的事件eventhandler上attach自己的事件方法就好了如:this.But ...

  7. java getDocumentBase() 得到的文件夹路径

    参考一个百度知道上的回答 举例说来,假设你的项目文件是xx,而这个xx文件夹是在D盘下的yy文件夹里,即项目文件的完整路径D:\yy\xx,则编译运行文件后,在xx文件夹里会产生名为build的文件夹 ...

  8. poj2573Bridge(过桥问题)

    链接 A,B为最快和次快 有两种方式可以使c,d过桥 一是a与c一起走,a回来接d再与d一起走,一直到对岸人为0为止 而是 a与b一起走 a回来送灯 c与d一起走 b回来送灯 重复此过程. 只剩2人时 ...

  9. Oracle 用到的服务

    1.Oracle ORCL VSS Writer Service Oracle卷映射拷贝写入服务,VSS(Volume ShadowCopy Service)能够让存储基础设备(比如磁盘,阵列等)创建 ...

  10. WPF学习07:MVVM 预备知识之数据绑定

    MVVM是一种模式,而WPF的数据绑定机制是一种WPF内建的功能集,两者是不相关的. 但是,借助WPF各种内建功能集,如数据绑定.命令.数据模板,我们可以高效的在WPF上实现MVVM.因此,我们需要对 ...