GPS座標変換ddmm.mmmm(度分)->dd.dddd(度)
1138 ワード
#include
#include
#include
int ddmm2dd(const char *ddmm, char *dd)
{
if (NULL == ddmm || NULL == dd)
{
return -1;
}
int lenSrc = strlen(ddmm)+1;
int lenMm = 0;
int flag = 1;
memcpy(dd,ddmm,lenSrc);
char *pcMm;
double dMm;
int iMm;
/* pcMm */
pcMm = strstr(dd,".");
if (pcMm == NULL) /* */
{
pcMm = dd+strlen(dd)-2;
iMm = atoi(pcMm);
dMm = iMm /60.0;
}
else /* */
{
/* */
if (pcMm - dd > 2)
{
pcMm = pcMm - 2;
}
else /* , */
{
pcMm = dd;
flag = 0;
}
/* */
dMm = atof(pcMm);
/* */
dMm /= 60.0;
}
/* */
sprintf(pcMm,"%lf",dMm);
if ( flag )
{
/* 0 */
strcpy(pcMm,pcMm+1);
}
/* 6 */
pcMm = strstr(dd,".");
lenMm = strlen(pcMm);
if ( lenMm > (6+2))
{
memset(pcMm+6+2,0,lenMm-6-2);
}
return 1;
}
int main()
{
char ddmm[32];
char dd[32];
while(scanf("%s",ddmm))
{
if ( ddmm2dd(ddmm,dd) >=0 )
printf("%s
",dd);
}
return 0;
}