C語(yǔ)言 坐標(biāo)移動(dòng)詳解及實(shí)例代碼
題目描述
開(kāi)發(fā)一個(gè)坐標(biāo)計(jì)算工具, A表示向左移動(dòng),D表示向右移動(dòng),W表示向上移動(dòng),S表示向下移動(dòng)。從(0,0)點(diǎn)開(kāi)始移動(dòng),從輸入字符串里面讀取一些坐標(biāo),并將最終輸入結(jié)果輸出到輸出文件里面。
輸入:
合法坐標(biāo)為A(或者D或者W或者S) + 數(shù)字(兩位以內(nèi))
坐標(biāo)之間以;分隔。
非法坐標(biāo)點(diǎn)需要進(jìn)行丟棄。如AA10; A1A; $%$; YAD; 等。
下面是一個(gè)簡(jiǎn)單的例子 如:
A10;S20;W10;D30;X;A1A;B10A11;;A10;
處理過(guò)程:
起點(diǎn)(0,0) + A10 = (-10,0) + S20 = (-10,-20) + W10 = (-10,-10) + D30 = (20,-10) + x = 無(wú)效 + A1A = 無(wú)效 + B10A11 = 無(wú)效 + 一個(gè)空 不影響 + A10 = (10,-10)
結(jié)果 (10, -10)
輸入描述:
一行字符串
輸出描述:
最終坐標(biāo),以,分隔
輸入例子:
A10;S20;W10;D30;X;A1A;B10A11;;A10;
輸出例子:
10,-10
Code:
#include<iostream> #include<string> using namespace std; bool isValid(string s, char &key, int &step){ if (s.size()<2 || s.size()>3)return false; if (s[0] != 'A' && s[0] != 'D' && s[0] != 'W' && s[0] != 'S') return false; key = s[0]; if (s.size() == 2 && s[1] >= '0' && s[1] <= '9'){ step = s[1] - '0'; return true; } if (s.size() == 3 && s[1] >= '0' && s[1] <= '9' && s[2] >= '0' && s[2] <= '9'){ step = (s[1] - '0') * 10 + (s[2] - '0'); return true; } return false; } void caculator(string s, int &x, int &y, char key, int step){ switch (key){ case 'A': x -= step; break; case 'D': x += step; break; case 'W': y += step; break; case 'S': y -= step; break; } return; } int main(){ string str; while (cin >> str){ int x = 0; int y = 0; int i = 0; while (i<str.size()){ string temp; char key; int step; while (str[i] != ';'){ temp.push_back(str[i]); i++; } if (isValid(temp, key, step)) caculator(temp, x, y, key, step); i++; } cout << x << ',' << y<<endl; //must add endl(wtf...,waste time) } return 0; }
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
- c語(yǔ)言計(jì)算三角形面積代碼
- C語(yǔ)言中字符的輸入輸出以及計(jì)算字符個(gè)數(shù)的方法詳解
- C語(yǔ)言求冪計(jì)算的高效解法
- C語(yǔ)言實(shí)現(xiàn)計(jì)算樹的深度的方法
- C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 安裝OpenMPI來(lái)配合C語(yǔ)言程序進(jìn)行并行計(jì)算
- C語(yǔ)言科學(xué)計(jì)算入門之矩陣乘法的相關(guān)計(jì)算
- C語(yǔ)言簡(jiǎn)單實(shí)現(xiàn)計(jì)算字符個(gè)數(shù)的方法
- 北郵計(jì)算機(jī)考研復(fù)試題的C語(yǔ)言解答精選
- C語(yǔ)言中計(jì)算二叉樹的寬度的兩種方式
- C語(yǔ)言實(shí)現(xiàn)直角坐標(biāo)轉(zhuǎn)換為極坐標(biāo)的方法
相關(guān)文章
C++入門之vector的底層實(shí)現(xiàn)詳解
這篇文章主要為大家介紹了C++入門之vector的底層實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2021-11-11C++實(shí)現(xiàn)LeetCode(37.求解數(shù)獨(dú))
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(37.求解數(shù)獨(dú)),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07c語(yǔ)言基于stdarg.h的可變參數(shù)函數(shù)的用法
本篇文章主要介紹了c語(yǔ)言基于stdarg.h的可變參數(shù)函數(shù)的用法,詳細(xì)的介紹了可變參數(shù)函數(shù)的詳細(xì)用法和源碼實(shí)例,有興趣的可以了解一下2017-07-07C++的try塊與異常處理及調(diào)試技術(shù)實(shí)例解析
這篇文章主要介紹了C++的try塊與異常處理及調(diào)試技術(shù)實(shí)例解析,有助于讀者加深對(duì)try塊調(diào)試技術(shù)的認(rèn)識(shí),需要的朋友可以參考下2014-07-07用C++類實(shí)現(xiàn)單向鏈表的增刪查和反轉(zhuǎn)操作方法
下面小編就為大家?guī)?lái)一篇用C++類實(shí)現(xiàn)單向鏈表的增刪查和反轉(zhuǎn)操作方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-04-04學(xué)習(xí)C語(yǔ)言要掌握的幾個(gè)庫(kù)
本文給大家分享的是網(wǎng)友提出的學(xué)習(xí)C語(yǔ)言要掌握的幾個(gè)庫(kù),這里分享給大家,有需要的小伙伴可以參考下。2015-07-07關(guān)于C/C++中可變參數(shù)的詳細(xì)介紹(va_list,va_start,va_arg,va_end)
可變參數(shù)的函數(shù)原理其實(shí)很簡(jiǎn)單,而va系列是以宏定義來(lái)定義的,實(shí)現(xiàn)跟堆棧相關(guān).我們寫一個(gè)可變函數(shù)的C函數(shù)時(shí),有利也有弊,所以在不必要的場(chǎng)合,我們無(wú)需用到可變參數(shù)。如果在C++里,我們應(yīng)該利用C++的多態(tài)性來(lái)實(shí)現(xiàn)可變參數(shù)的功能,盡量避免用C語(yǔ)言的方式來(lái)實(shí)現(xiàn)2013-10-10OpenCV基于稠密光流實(shí)現(xiàn)視頻跟蹤詳解
這篇文章主要為大家詳細(xì)介紹了OpenCV如何基于稠密光流實(shí)現(xiàn)視頻跟蹤功能,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,需要的可以參考一下2023-02-02