简单的小题集(九)

2023-12-12 13:20
文章标签 简单 小题

本文主要是介绍简单的小题集(九),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 一、座位安排与查询
  • 二、Dfs 简单签到题


一、座位安排与查询

:Du 老师监考一向严格,期末监考又轮到他监考,当他走进教室的时候发现很
多人在窃窃私语,为了维护良好的考场秩序,他随机给学生分配了座位和编号。如下图所
示:在 5 行 5 列座位的教室中,有 25 个学生的话,他将随机抽人按如下的螺旋顺序就坐,
并且第 k 个被抽到的学生的编号为 k。现在给定座位的行数 r 和列数 c(r = c,并且 r 为奇
数),t 次询问第 p 行 q 列的编号是多少?

#include <stdio.h>
int main() {int r, c, t, p, q;scanf("%d%d%d", &r, &c, &t);int arr[r][c];//初始化二维数组for(int i=0; i<r; i++)for(int j=0; j<c; j++)arr[i][j] = 0;int num = 1;for(int i=0; i<r*c; i++){//螺旋顺序搜索arr[i/c][i%c] = num++;}while(t--){scanf("%d%d", &p, &q);printf("%d\n", arr[p-1][q-1]);}return 0;
}

二、Dfs 简单签到题

昨晚很多人说期末考试要手下留情,Du 老师一想也有道理,于是这道 DFS 题
就送分啦!现在给定一张 n 行 m 列的长方形二维地图,地图中仅有两种标记,X 和 O,如
果 O 所在的区域被 X 全包围,那么 O 要被 X 替换,如下所示,左侧的地图将被替换为右边的
地图 ,注意搜索区域只需要搜索 4 联通即可。

#include <stdio.h>
#define N 4 
#define M 5
char map[N][M];
int visited[N][M];
int dx[4]={0,1,0,-1}; 
int dy[4]={1,0,-1,0};
void dfs(int x,int y){visited[x][y] = 1;for(int i=0; i<4; i++){int nx = x + dx[i];int ny = y + dy[i];if(nx<0 || nx>=N || ny<0 || ny>=M || map[nx][ny]=='X' || visited[nx][ny]==1)continue;dfs(nx,ny);}
}
int main(){int n,m;scanf("%d %d", &n, &m);for(int i=0; i<n; i++){for(int j=0; j<m; j++){ scanf(" %c", &map[i][j]);}}for(int i=0; i<n; i++)for(int j=0; j<m; j++) if(map[i][j]=='O'&&!visited[i][j])dfs(i,j);for(int i=0; i<n; i++){ for(int j=0; j<m; j++)printf("%c", map[i][j]);printf("\n");}return 0;
}

这篇关于简单的小题集(九)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/484794

相关文章

一份LLM资源清单围观技术大佬的日常;手把手教你在美国搭建「百万卡」AI数据中心;为啥大模型做不好简单的数学计算? | ShowMeAI日报

👀日报&周刊合集 | 🎡ShowMeAI官网 | 🧡 点赞关注评论拜托啦! 1. 为啥大模型做不好简单的数学计算?从大模型高考数学成绩不及格说起 司南评测体系 OpenCompass 选取 7 个大模型 (6 个开源模型+ GPT-4o),组织参与了 2024 年高考「新课标I卷」的语文、数学、英语考试,然后由经验丰富的判卷老师评判得分。 结果如上图所

回调的简单理解

之前一直不太明白回调的用法,现在简单的理解下 就按这张slidingmenu来说,主界面为Activity界面,而旁边的菜单为fragment界面。1.现在通过主界面的slidingmenu按钮来点开旁边的菜单功能并且选中”区县“选项(到这里就可以理解为A类调用B类里面的c方法)。2.通过触发“区县”的选项使得主界面跳转到“区县”相关的新闻列表界面中(到这里就可以理解为B类调用A类中的d方法

自制的浏览器主页,可以是最简单的桌面应用,可以把它当成备忘录桌面应用

自制的浏览器主页,可以是最简单的桌面应用,可以把它当成备忘录桌面应用。如果你看不懂,请留言。 完整代码: <!DOCTYPE html><html lang="zh-CN"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><ti

python实现最简单循环神经网络(RNNs)

Recurrent Neural Networks(RNNs) 的模型: 上图中红色部分是输入向量。文本、单词、数据都是输入,在网络里都以向量的形式进行表示。 绿色部分是隐藏向量。是加工处理过程。 蓝色部分是输出向量。 python代码表示如下: rnn = RNN()y = rnn.step(x) # x为输入向量,y为输出向量 RNNs神经网络由神经元组成, python

宝塔面板部署青龙面板教程【简单易上手】

首先,你得有一台部署了宝塔面板的服务器(自己用本地电脑也可以)。 宝塔面板部署自行百度一下,很简单,这里就不走流程了,官网版本就可以,无需开心版。 首先,打开宝塔面板的软件商店,找到下图这个软件(Docker管理器)安装,青龙面板还是安装在docker里,这里依赖宝塔面板安装和管理docker。 安装完成后,进入SSH终端管理,输入代码安装青龙面板。ssh可以直接宝塔里操作,也可以安装ssh连接

js小题:通过字符串执行同名变量怎么做

在JavaScript中,你不能直接使用一个字符串来直接引用一个变量,因为JavaScript是一种静态类型语言(尽管它的类型在运行时可以变化),变量的名字在编译时就被确定了。但是,有几种方法可以实现类似的功能: 使用对象(或Map)来存储变量: 你可以使用一个对象来存储你的变量,然后使用字符串作为键来访问这些变量。 let myVars = { 'var1': 'Hello', 'var

XMG Quartz2D的简单使用

// //  Quratz2DView.m //  Quartz2D // //  Created by 王宁 on 16/5/6. //  Copyright © 2016年 ylshmacmini. All rights reserved. // #import "Quratz2DView.h" //Quartz@2D是一个二维绘图引擎,同时支

网页脚本输入这么简单

如何在网页中进行脚本操作呢? 研究了一下,很简单,用google浏览器的Console直接操作javaScript。思路: Created with Raphaël 2.1.0 开始 输入(如何输入) 点击(如何点击) 结束 下面是,通过脚本刷直播屏的实现,直接在Console输入即可 var words=new Arra

Linux网络编程之简单并发服务器

1.概念 与前面介绍的循环服务器不同,并发服务器对服务请求并发处理。而循环服务器只能够一个一个的处理客户端的请求,显然效率很低. 并发服务器通过建立多个子进程来实现对请求的并发处理,但是由于不清楚请求客户端的数目,因此很难确定子进程的数目。因此可以动态增加子进程与事先分配的子进程相结合的方法来实现并发服务器。 2. 算法流程 (1)TCP简单并发服务器:     服务器子进程1:

简单 使用 的makefile编写 框架

1、指定编译器,如海思平台:CROSS_COMPILE=arm-hisiv100nptl-linux-; 2、指定编译工具:GCC=$(CROSS_COMPILE)gcc   CC=$(CROSS_COMPILE)g++; 3、使用 export 导出 子makefile 要用的变量; 4、定义变量的形式  指定 工程源文件 需要使用到的 “宏”,在后面的 LDFLAGS 里面使用 -D将其