這道題題意說得不太清楚。。。參考了網上的一些解法,總結如下:
比較簡單的解法:http://blog.csdn.net/zhaorongxia/article/details/7629858
c語言版:
#include<stdio.h>
#include<string.h>
void qq(char *a)
{
int len,i;
len=strlen(a)-1;
for(i=len;i>=0;i--)
{
if(a[i]=='0') len--;//去掉小數點後的0
else break;
}
if(a[len]=='.') len--; //如果小數點後全是0,那小數點也得去掉
a[len+1]='\0'; //通過加結束標誌來去掉
}
int main()
{
int i,len;
char a[50000],b[50000];
while(scanf("%s%s",a,b) != EOF)//scanf("%s%s",a,b)==2
{
len=strlen(a);
for(i=0;i<len;i++)
{
if(a[i]=='.') //對有小數點的數據處理
qq(a);
}
len=strlen(b);
for(i=0;i<len;i++)
{
if(b[i]=='.')
qq(b);
}
if(strcmp(a,b))
printf("NO\n");
else
printf("YES\n");
}
return 0;
}
此解法對於-0和0 002和2 001.00和1都輸出NO,即只考慮小數末尾多餘的0其它參考解法:http://blog.csdn.net/xujinsmile/article/details/7833139
看了Java版:http://www.cnblogs.com/zhangshu/archive/2011/09/21/2184518.html後,感覺Java語言真強大,而自己在各種語言上都不太精通,需要選擇一門語言好好深入學一下。