2GPS數據處理(5分)

題目內容:
NMEA-0183協議是為了在不同的GPS(全球定位系統)導航設備中建立統一的BTCM(海事無線電技術委員會)標準,由美國國家海洋電子協會(NMEA-The National Marine Electronics Associa-tion)制定的一套通訊協議。GPS接收機根據NMEA-0183協議的標準規范,將位置、速度等信息通過串口傳送到PC機、PDA等設備。

NMEA-0183協議是GPS接收機應當遵守的標準協議,也是目前GPS接收機上使用最廣泛的協議,大多數常見的GPS接收機、GPS數據處理軟件、導航軟件都遵守或者至少兼容這個協議。

NMEA-0183協議定義的語句非常多,但是常用的或者說兼容性最廣的語句只有$GPGGA、$GPGSA、$GPGSV、$GPRMC、$GPVTG、$GPGLL等。

其中$GPRMC語句的格式如下:

$GPRMC,024813.640,A,3158.4608,N,11848.3737,E,10.05,324.27,150706,,,A*50

這里整條語句是一個文本行,行中以逗號“,”隔開各個字段,每個字段的大小(長度)不一,這里的示例只是一種可能,并不能認為字段的大小就如上述例句一樣。

字段0:$GPRMC,語句ID,表明該語句為Recommended Minimum Specific GPS/TRANSIT Data(RMC)推薦最小定位信息
字段1:UTC時間,hhmmss.sss格式
字段2:狀態,A=定位,V=未定位
字段3:緯度ddmm.mmmm,度分格式(前導位數不足則補0)
字段4:緯度N(北緯)或S(南緯)
字段5:經度dddmm.mmmm,度分格式(前導位數不足則補0)
字段6:經度E(東經)或W(西經)
字段7:速度,節,Knots
字段8:方位角,度
字段9:UTC日期,DDMMYY格式
字段10:磁偏角,(000 - 180)度(前導位數不足則補0)
字段11:磁偏角方向,E=東W=西
字段16:校驗值

這里,“”為校驗和識別符,其后面的兩位數為校驗和,代表了“$”和“”之間所有字符(不包括這兩個字符)的異或值的十六進制值。上面這條例句的校驗和是十六進制的50,也就是十進制的80。

提示:運算符的作用是異或。將$和*之間所有的字符做運算(第一個字符和第二個字符異或,結果再和第三個字符異或,依此類推)之后的值對65536取余后的結果,應該和*后面的兩個十六進制數字的值相等,否則的話說明這條語句在傳輸中發生了錯誤。注意這個十六進制值中是會出現A-F的大寫字母的。另外,如果你需要的話,可以用Integer.parseInt(s)從String變量s中得到其所表達的整數數字;而Integer.parseInt(s, 16)從String變量s中得到其所表達的十六進制數字

現在,你的程序要讀入一系列GPS輸出,其中包含$GPRMC,也包含其他語句。在數據的最后,有一行單獨的
END
表示數據的結束。

你的程序要從中找出$GPRMC語句,計算校驗和,找出其中校驗正確,并且字段2表示已定位的語句,從中計算出時間,換算成北京時間。一次數據中會包含多條$GPRMC語句,以最后一條語句得到的北京時間作為結果輸出。

你的程序一定會讀到一條有效的$GPRMC語句。

輸入格式:
多條GPS語句,每條均以回車換行結束。最后一行是END三個大寫字母。

輸出格式:
6位數時間,表達為:
hh:mm:ss
其中,hh是兩位數的小時,不足兩位時前面補0;mm是兩位數的分鐘,不足兩位時前面補0;ss是兩位數的秒,不足兩位時前面補0。

輸入樣例:
$GPRMC,024813.640,A,3158.4608,N,11848.3737,E,10.05,324.27,150706,,,A*50
END

輸出樣例:
10:48:13
時間限制:500ms內存限制:32000kb

package pro;
//1.讀入多條GPS語句,最后一行是END
//2.存入數組
//2.5看看是否定位
//3.進行異或運算
//4.與校驗和比較
//4.5若有多條已定位并且校驗和正確的語句,則輸出最后一條的時間
//5.輸出北京時間
import java.util.Scanner;
                    
public class Main2 {
//  public static void yihuo(int index,int value,char[]c) {
//      for(int i=2;i<index;i++) {
//          value=value^c[i];
//      }
//  }
    public static void main(String[] args) {
        Scanner in=new Scanner(System.in);
        String str=in.nextLine();
        char[]c=new char[200];
        char[]c2=new char[6];
        String s1="";
        String revalue="",temp="";
        String revalue2="",temp2="0";
        int index2=0;
        while(!str.equals("END")) {
            c=str.toCharArray();
            int value=c[1];
            int index=str.indexOf("*");
            //異或運算
//          yihuo(index,value,c);
            for(int i=2;i<index;i++) {
                value=value^c[i];
            }
            int a=value%65536;
            index2=str.indexOf(",");
            temp=str.substring(index+1);
            s1=str.substring(18, 19);
            str=in.nextLine();
            revalue=Integer.toHexString(a).toUpperCase();
            if(revalue.equals(temp)) {
                revalue2=revalue;
                temp2=temp;
            }else {
            }
    }
        if(revalue2.equals(temp2)&&s1.equals("A")) {
            for(int i1=0;i1<6;i1++) {
                c2[i1]=c[index2+1+i1];
            }
            int time=Character.getNumericValue(c2[0])*10+Character.getNumericValue(c2[1]);
            if(time>=16) {
                System.out.print(String.format("%02d", (time-16)));
            }
            else {
                System.out.print(String.format("%02d", (time+8)));
            }
            
            System.out.print(":");
            System.out.print(c2[2]);
            System.out.print(c2[3]);
            System.out.print(":");
            System.out.print(c2[4]);
            System.out.print(c2[5]);    
        }
        else {
        }
        
        in.close();
    }
}

我的代碼就是不通過OJ
這是別人的代碼,我也覺得我的代碼邏輯太混亂,不知道怎么辦.
除了邏輯混亂之外,我還太粗心了。讀了很多遍題目,還梳理了步驟,結果還是漏掉了兩個判斷條件(已定位A)和%65536.(雖然后來添加了,發現無卵用)
可能還是,題做的,太少吧。
以后,一定在下手敲代碼之前整理好邏輯,花更多時間!!!!

import java.util.Scanner;

public class Main {
 
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        String GPRS = in.nextLine();
        int a = 0;
        String jiaoyanzhi = "";
         
        String result = "";
         
        while ( !GPRS.equals("END"))
        {
            char c = GPRS.charAt(1);
           
                int xinghao = GPRS.indexOf('*');
                int douhao1 = GPRS.indexOf(',');
                int douhao2 = GPRS.indexOf(',', douhao1 + 1);
                char dingwei = GPRS.charAt(douhao2 + 1);
                String yuanjiaoyanzhi = GPRS.substring(xinghao+1);
                for ( int i = 2; i < xinghao; i++)
                {
                    char d = GPRS.charAt(i);
                    a = c ^ d;
                    c = (char)a;
                }
                jiaoyanzhi = Integer.toHexString(a).toUpperCase();
                if (jiaoyanzhi.equals(yuanjiaoyanzhi) && dingwei == 'A')
                {
                    int dian = GPRS.indexOf('.');
                    String UTC1 = GPRS.substring(douhao1 + 1, dian);
                    int UTC = Integer.valueOf(UTC1);
                    int second = UTC % 100 ;
                    int min = ((UTC - second) /100) % 100 ;
                    int hour = (UTC - min * 100 -second) /10000 ;
                    int hourB;
                    if (hour < 16)    //時間換算部分
                    {
                        hourB = hour + 8;
                    }
                    else
                    {
                        hourB = hour - 16;
                    }
                    result = String.format("%02d", hourB) + ":" + String.format("%02d", min) + ":" + String.format("%02d", second);
                }
                GPRS = in.nextLine();
            
        }
        System.out.println(result);
         
    in.close();
    }
 
}
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容