機器人能否返回原點

来源:https://www.cnblogs.com/mooysy/p/18016073
-Advertisement-
Play Games

洛谷試煉場的題目確實很具有代表性,但是近幾年以來,又有許多經典題目出現在 OI 界中,這個大題單就是作為洛谷試煉場的擴展和補充。 目錄新版本食用指南更新日誌題單Part 0 試機題Part 1 入門階段Part 2 基礎演算法Part 3 搜索Part 4 動態規劃Part 4.1-4.4 動態規劃P ...


在二維平面上,有一個機器人從原點 (0, 0) 開始。給出它的移動順序,判斷這個機器人在完成移動後是否在 (0, 0) 處結束。

移動順序由字元串 moves 表示。字元 move[i] 表示其第 i 次移動。機器人的有效動作有 R(右),L(左),U(上)和 D(下)。

如果機器人在完成所有動作後返回原點,則返回 true。否則,返回 false。

註意:機器人“面朝”的方向無關緊要。 “R” 將始終使機器人向右移動一次,“L” 將始終向左移動等。此外,假設每次移動機器人的移動幅度相同。

示例1:

輸入: moves = "UD"
輸出: true
解釋:機器人向上移動一次,然後向下移動一次。所有動作都具有相同的幅度,因此它最終回到它開始的原點。因此,我們返回 true。

示例2:

輸入: moves = "LL"
輸出: false
解釋:機器人向左移動兩次。它最終位於原點的左側,距原點有兩次 “移動” 的距離。我們返回 false,因為它在移動結束時沒有返回原點。

提示:

  • 1 <= moves.length <= 2 * 104
  • moves 只包含字元 'U', 'D', 'L' 和 'R'

思路:
使用一個二維數組dir表示移動方向,然後使用switch將字元串映射為dir每行的索引。

int map(char ch){
    switch(ch){
        case 'U':
            return 0;
        case 'R':
            return 1;
        case 'D':
            return 2;
        case 'L':
            return 3;
        default:
            return 0;
    }
}
bool judgeCircle(char* moves) {
    int dir[][2] = {{1,0},{0,1},{-1,0},{0,-1}};
    int row = 0,col = 0;
    for(int i=0;moves[i]!='\0';i++){
        int idx = map(moves[i]);
        row+=dir[idx][0];
        col+=dir[idx][1];
    }
    if(row!=0||col!=0){
        return false; 
    }
    return true;
}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • pandas的DataFrame功能強大自不必說,它可以幫助我們極大的提高統計分析的效率。 不過,使用DataFrame開發我們的分析程式的時候,經常需要列印出DataFrame的內容,以驗證和調試數據的處理是否正確。 在命令行中雖然可以直接列印出DataFrame的內容,但是閱讀比較困難。正好前段 ...
  • python編譯相關 具體編譯步驟 Python代碼的編譯和執行過程可以更詳細地描述如下: 詞法分析(Lexical Analysis)和語法分析(Syntax Analysis): Python解釋器首先會對源代碼進行詞法分析和語法分析。詞法分析器會將源代碼分解成詞法單元(tokens),這些單元 ...
  • 雲計算 - 負載均衡SLB方案全解與實戰,介紹SLB的核心技術、用戶最佳實踐、阿裡雲 SLB產品舉例、應用場景。 關註【TechLeadCloud】,分享互聯網架構、雲服務技術的全維度知識。作者擁有10+年互聯網服務架構、AI產品研發經驗、團隊管理經驗,同濟本復旦碩,復旦機器人智能實驗室成員,阿裡雲 ...
  • 1、定義 Go語言支持一種特殊的欄位只需要提供類型而不需要寫欄位名的欄位**,**稱之為匿名欄位或者嵌套欄位。 所謂匿名欄位實際上是一種結構體嵌套的方式,所以也可以稱作嵌套欄位。 這種方式可以實現組合復用,即通過匿名欄位,結構體可以直接訪問嵌套結構體的欄位和方法,而無需通過欄位名或類型進行嵌套。 2 ...
  • 目錄: OpenID 與 OAuth2 基礎知識 Blazor wasm Google 登錄 Blazor wasm Gitee 碼雲登錄 Blazor OIDC 單點登錄授權實例1-建立和配置IDS身份驗證服務 Blazor OIDC 單點登錄授權實例2-登錄信息組件wasm Blazor OID ...
  • 最近需要在伺服器上運行一些時間很長的命令,想讓伺服器自動通知我什麼時候命令完成,通過命令結束後發送郵件給我來提醒。 安裝 msmtp 和 mail # RedHat 系 sudo dnf install msmtp mailx # Debian 系 sudo apt install msmtp ma ...
  • 程式說明: 《幾何衝刺》是一款基於Scratch平臺開發的跑酷類游戲程式。在這個游戲中,玩家控制一個黃色的小方塊,在快速向前衝刺的過程中躲避各種障礙物。通過按下鍵盤上的上方向鍵,玩家可以操作小方塊進行跳躍,以避開途中的障礙。游戲的目標是儘可能讓黃色小方塊跑得更遠,挑戰玩家的反應速度和操作技巧。 小虎 ...
  • 關註我,緊跟本系列專欄文章,咱們下篇再續! 作者簡介:魔都技術專家兼架構,多家大廠後端一線研發經驗,各大技術社區頭部專家博主,編程嚴選網創始人。具有豐富的引領團隊經驗,深厚業務架構和解決方案的積累。 負責: 中央/分銷預訂系統性能優化 活動&優惠券等營銷中台建設 交易平臺及數據中台等架構和開發設計 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...