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; }