HDU2054_A == B ?【模拟题】【大数】【水的问题】
Problem Description
Give you two numbers A and B, if A is equal to B, you should print "YES", or print "NO".
Input
each test case contains two numbers A and B.
Output
for each case, if A is equal to B, you should print "YES", or print "NO".
Sample Input
1 2
2 2
3 3
4 3
Sample Output
NO
YES
YES
NO
题目大意:给你两个数A和B,推断A和B是否相等,若相等输出"YES"。
否则输出"NO"。
思路:题目没有给出A、B的数据规模,这里就是个大数题。把A、B用
字符数组存起来。标记A、B的正负号,若为正,则标记为1,若为负。
则标记为0。将字符数组内的'-'赋值为'0',然后将整数前的零和小数部分
后边的零清除,然后用数组将整数部分和小数部分分别存起来。之后分别
比較A、B的整数部分和小数部分是否相等。注意A、B可能为整数或是小
数,尤其注意A、B可能会在整数部分前边有N个零或者小数部分后边有N
个零,比方00012、123.123000、0.00、012.200等等。详细解题过程
看以下代码。
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
char A[20020],B[20020];
char a[20020],aa[20020],b[20020],bb[20020];
int main()
{
int flagA,flagB,lenA,lenB,markA,markB;
while(~scanf("%s%s",A,B))
{
memset(a,0,sizeof(a));//存A的整数部分
memset(b,0,sizeof(b));//存B的整数部分
memset(aa,0,sizeof(aa));//存A的小数部分
memset(bb,0,sizeof(bb));//存B的小数部分
flagA = flagB = 1;//标记正负数,1为整数,0为负数
markA = markB = 0;//标记小数点,1为有小数点,0为没有小数点 if(A[0] == '-')//标记并清除A、B的正负号
{
flagA = 0;
A[0] = '0';
}
if(B[0] == '-')
{
flagB = 0;
B[0] = '0';
} lenA = strlen(A);
lenB = strlen(B);
int numa = 0,i; for(i = 0; i < lenA; i++)//清除A的整数部分前面的零
if(A[i]!='0')
break;
if(i==lenA || A[i]=='.')//若整数部分全为0,则数组a为"0"
a[0] = '0';
for(; i < lenA; i++)//用数组a记录A的整数部分
{
if(A[i]!='.')
a[numa++] = A[i];
else
{
markA = 1;
break;
}
}
int j,numaa = 0;
for(j = lenA-1;j > i; j--)//清除A小数部分后边的零
if(A[j]!='0')
break;
if(j == i)//若小数部分全为0,则数组aa为"0"
aa[0] = '0';
for(;j > i; j--)//用数组aa记录A的小数部分
{
aa[numaa++] = A[j];
}
//B和A的处理一样
int k,l;
for(k = 0; k < lenB; k++)
if(B[k]!='0')
break;
if(k == lenB || B[k]=='.')
b[0] ='0';
int numb = 0;
for(; k < lenB; k++)
{
if(B[k]!='.')
b[numb++] = B[k];
else
{
markB = 1;
break;
} } int numbb = 0;
for(l = lenB-1;l > k; l--)
if(B[l]!='0')
break;
if(l==k)
bb[0]='0';
for(;l > k; l--)
{
bb[numbb++] = B[l];
} if(markA == 0)
aa[0] = '0';
if(markB == 0)
bb[0] = '0';
if(flagA==flagB && strcmp(a,b)==0 && strcmp(aa,bb)==0)//推断A、B是否相等
printf("YES\n");
else
printf("NO\n");
memset(A,0,sizeof(A));
memset(B,0,sizeof(B));
} return 0;
}
版权声明:本文博主原创文章,博客,未经同意不得转载。
HDU2054_A == B ?【模拟题】【大数】【水的问题】的更多相关文章
- Leetcode 8. String to Integer (atoi)(模拟题,水)
8. String to Integer (atoi) Medium Implement atoi which converts a string to an integer. The functio ...
- HDU-1042-N!(Java大法好 && HDU大数水题)
N! Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others) Total Subm ...
- POJ 2506 Tiling dp+大数 水题
大致题意:现有两种方块(1X2,2X2),方块数量无限制.问用这两种方块填满2Xn的矩阵的填法有多少种. 分析:通俗点说,找规律.专业化一点,动态规划. 状态d[i],表示宽度为i的填法个数. 状态转 ...
- poj 1008:Maya Calendar(模拟题,玛雅日历转换)
Maya Calendar Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 64795 Accepted: 19978 D ...
- 《ACM国际大学生程序设计竞赛题解Ⅰ》——模拟题
这篇文章来介绍一些模拟题,即一类按照题目要求将现实的操作转换成程序语言. zoj1003: On every June 1st, the Children's Day, there will be a ...
- POJ 模拟题集合
http://www.cppblog.com/Uriel/articles/101592.html 感觉这个暑假没有去年有激情啊,,,还没到状态就已经块上学了,,, 真是弱暴了,,,找几道模拟题刷刷. ...
- NOIP2010-普及组复赛-第二题-接水问题
题目描述 Description 学校里有一个水房,水房里一共装有 m 个龙头可供同学们打开水,每个龙头每秒钟的供水量相等,均为 1. 现在有 n 名同学准备接水,他们的初始接水顺序已经确定.将这些 ...
- hdu_1034(模拟题)
很久没有打模拟题了,再次总结一下模拟题的做法: 仔细分析题意,弄清楚过程 理清楚模拟步骤,严格按照步骤编写代码 添加中间输出测试每步结果 虽然这是一个很简单的水题,但是没有松哥帮忙还是卡了很久,因为没 ...
- NOIP模拟题汇总(加厚版)
\(NOIP\)模拟题汇总(加厚版) T1 string 描述 有一个仅由 '0' 和 '1' 组成的字符串 \(A\),可以对其执行下列两个操作: 删除 \(A\)中的第一个字符: 若 \(A\)中 ...
- Codeforces Gym 100269B Ballot Analyzing Device 模拟题
Ballot Analyzing Device 题目连接: http://codeforces.com/gym/100269/attachments Description Election comm ...
随机推荐
- 解决cognos以远程db2数据库为数据源的连接失败问题
问题现象为使用远程的db2来创建数据源时,测试连接时不通,好多人都说是驱动问题,将db2cc.jar拷贝到某lib目录下,实验不通: 在看到某哥们的博客时最后提了一句,说需要将数据库catalog到本 ...
- Notepad++背景颜色设置
经常试用notepad++看代码,白色的背景连续看的时间长了眼睛很容变花,所以找了相关的设置选项,分享给大家 具体设置步骤如下: 然后如下设置 这样前景色背景色已经发生改变了哟,下面再修改下选中行的背 ...
- PHP学习笔记三
<?php $a=56; $b=++$a; //等价于 $a=$a+1; $b=$a; /////2. $e=false||true;//结果为true $f=false or true;//输 ...
- 【转】GATT Profile 简介
网上关于讲解 BLE 的内容比较少,看到这篇文章写的非常详细 Introduction to Bluetooth Low Energy,作为 BLE 的入门时介绍是非常合适的.本文主要翻译了一下这篇文 ...
- sizeof 和 strlen
1. sizeof 1.1 sizeof是一个独立的运算符,不是函数.sizeof给我们提供有关数据项目所分配的内存的大小.例如: 1 2 cout << sizeof(long) < ...
- u-boot基本命令
1.查看环境变量 printenv 2.网络相关命令 设置开发板ip:setenv ipaddr 192.168.2.110 设置子网掩码:setenv netmask 255.255.255.0 设 ...
- C#与SQLite数据库
1.添加引用 System.Data.SQLite.dll 2.using System.Data.SQLite; 3.原理步骤: string path = "c:\\mydb.db&qu ...
- 【转载】MongoDB中的MapReduce 高级操作介绍
转载自残缺的孤独 1.概述 MongoDB中的MapReduce相当于关系数据库中的group by.使用MapReduce要实现两个函数Map和Reduce函数.Map函数调用emit(key,va ...
- margin-top失效及解决办法
现象:当两个空的块级元素嵌套时,如果内部的块设置有margin-top属性,而且父元素没有下边解决方法所述的特征,那么内部块的margin-top属性会绑架父元素(即将margin-top传递凌驾给了 ...
- 移动端zepto.js文件的构建
因为在zepto的官网http://www.zeptojs.cn/#download下载的文件只包括了默认的几个模块,这并不能全部适应我们所需功 能,还需要按自己需要去添加相应模块.所以需要去构建我们 ...