试题 算法提高 Cat And Mouse
2022/1/6 14:04:35
本文主要是介绍试题 算法提高 Cat And Mouse,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
试题 算法提高 Cat And Mouse
资源限制
时间限制:1.0s 内存限制:256.0MB
猫和老鼠在10×10的方格中运动(如图3-6),例如:
*...*..... ......*... ...*...*.. .......... ...*.C.... *.....*... ...*...... ..M......* ...*.*.... .*.*...... C=猫(CAT) M=老鼠(MOUSE) *=障碍物 .=空地
猫和老鼠每秒中走一格,如果在某一秒末它们在同一格中,我们称它们“相遇”。
注意:“对穿”是不算相遇的。猫和老鼠的移动方式相同:平时沿直线走,下一步如果会走到障碍物上去或者出界,就用1秒的时间做一个右转90°。一开始它们都面向北方。
编程计算多少秒以后他们相遇。
一道简单的模拟题,关键在于猫和老鼠是独立的个体,只要处理好每一秒内各自的动作即可实现。
代码如下:
#include <stdio.h> #include <stdlib.h> #include <math.h> #include <string.h> #include <stdbool.h> int* change(int direction, int old_x, int old_y){ // 依据前进方向进行移动 /* direction:0:北,1:东,2:南,3:西 */ int* new_loc = (int*)malloc(sizeof(int)*2); switch(direction){ case 0: new_loc[0] = old_x - 1; new_loc[1] = old_y; break; case 1: new_loc[0] = old_x; new_loc[1] = old_y + 1; break; case 2: new_loc[0] = old_x + 1; new_loc[1] = old_y; break; case 3: new_loc[0] = old_x; new_loc[1] = old_y - 1; break; } return new_loc; } void catMouseGame(char** graph, int cx, int cy, int cd, int mx, int my, int md, int count){ /* 参数说明: graph:地图(输入的二维数组) cx:老鼠所在位置的x轴坐标 cy:老鼠所在位置的y轴坐标 cd:老鼠当前的前进方向 mx:猫所在位置的x轴坐标 my:猫所在位置的y轴坐标 md:猫当前的前进方向 count:当前的秒数 */ if(cx == mx && cy == my){ // 如果两者坐标相同,即为结束 printf("%d", count); return; } /* 处理老鼠的位置 */ int* new_loc = change(md, mx, my); // 获取这一秒内的老鼠位置 int m_x = new_loc[0], m_y = new_loc[1]; if(m_x == 10 || m_y == 10 || m_x == -1 || m_y == -1 || graph[m_x][m_y] == '*'){ // 如果越界或者碰到障碍物,则改变方向,即旋转90度 md = (md+1) % 4; m_x = mx; m_y = my; } /* 处理猫的位置 */ new_loc = change(cd, cx, cy); // 获取这一秒内的猫位置 int c_x = new_loc[0], c_y = new_loc[1]; if(c_x == 10 || c_y == 10 || c_x == -1 || c_y == -1 || graph[c_x][c_y] == '*'){ // 如果越界或者碰到障碍物,则改变方向,即旋转90度 cd = (cd+1) % 4; c_x = cx; c_y = cy; } /* 开始移动 */ catMouseGame(graph, c_x, c_y, cd, m_x, m_y, md, count+1); } int main(){ char** graph = (char**)malloc(sizeof(char*)*10); int i = 0; for(i = 0; i < 10; i++){ graph[i] = (char*)malloc(sizeof(char)*10); scanf("%s", graph[i]); } catMouseGame(graph, 4, 5, 0, 7, 2, 0, 0); return 0; }
这篇关于试题 算法提高 Cat And Mouse的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南
- 2025-01-03图像文字理解,OCR、大模型还是多模态模型?PalliGema2在QLoRA技术上的微调与应用
- 2025-01-03混合搜索:用LanceDB实现语义和关键词结合的搜索技术(应用于实际项目)
- 2025-01-03停止思考数据管道,开始构建数据平台:介绍Analytics Engineering Framework
- 2025-01-03如果 Azure-Samples/aks-store-demo 使用了 Score 会怎样?
- 2025-01-03Apache Flink概述:实时数据处理的利器
- 2025-01-01使用 SVN合并操作时,怎么解决冲突的情况?-icode9专业技术文章分享