首页 > 编程语言 >AtCoder Beginner Contest 375 C题 (python解)

AtCoder Beginner Contest 375 C题 (python解)

时间:2024-10-23 21:00:10浏览次数:6  
标签:AtCoder Contest python 交换 网格 旋转 range 375

Panasonic Programming Contest 2024(AtCoder Beginner Contest 375)C - Spiral Rotation(python解)**

原题链接:

[(https://atcoder.jp/contests/abc375/tasks/abc375_c)]

题目简述:

这道题要求对一个 N x N 的网格进行特定的螺旋旋转操作,而这个 N 总是偶数。在这里,网格中的每个单元格可以是黑色(用 # 表示)或白色(用 . 表示)。我们需要根据题目的描述,通过一系列的操作最终输出网格的颜色状态。

思路:

​ 对于 i =1N/2,在每个 i进行 (i +1) %4 次旋转。也就是说:i =1 时执行2 次旋转 - i =2 时执行3 次旋转 - i =3 时执行0 次旋转 - i =4 时执行1 次旋转 -依此类推……

旋转的定义是将相应的颜色值从一个位置移动到另一个位置。

python代码

def func(N, i, A):
    r = N-1-i#计算当前层的右边界
    for j in range(i,r):# 执行四个位置的颜色值交换,实现螺旋旋转
        (A[j][r], A[r][N-1-j], A[N-1-j][i], A[i][j]) = (A[i][j], A[j][r], A[r][N-1-j], A[N-1-j][i])
def main():
    N = int(input())
    A = [list(input()) for _ in range(N)]#读取网格数据
    for i in range(N//2):# 遍历每一个层次,从外层到内层(共 N/2 层)
        for j in range((i+1)%4):# 根据当前层数 i计算旋转次数
            func(N, i, A)
    print("\n".join("".join(i) for i in A))# 输出最终的网格状态,将每一行转换为字符串,并用换行符连接
main()

自定义func(N, i, A) 函数:

  • i 是当前层的左边界,r 是右边界。
    通过一个循环,将当前层的四个位置的颜色值进行交换,实现旋转。

  • 逻辑如下:

    A[i][j](左上)交换到 A[j][r](右上)

    A[j][r]交换到 A[r][N-1-j](右下)

    A[r][N-1-j]交换到 A[N-1-j][i](左下)

    A[N-1-j][i]交换到 A[i][j](左上)

最后进行复杂度分析:

每一层的旋转操作是 O(N/2),因为每层的旋转交换只涉及该层的元素。

# 祝大家ACCCCCCCCC*

标签:AtCoder,Contest,python,交换,网格,旋转,range,375
From: https://www.cnblogs.com/666-777-eto/p/18498337

相关文章

  • Python多进程学习与使用:全面指南
    Python多进程学习与使用:全面指南目录引言什么是多进程?为什么使用多进程?Python中的多进程模块:multiprocessing创建进程的基本方法进程间通信进程池多进程与多线程的比较常见问题和解决方案最佳实践和性能优化实战项目:多进程文件处理系统总结引言在当今的计算环境中,充分利......
  • AtCoder Beginner Contest 376
    A-CandyButton#include<bits/stdc++.h>usingnamespacestd;usingi32=int32_t;usingi64=longlong;usingvi=vector<int>;usingpii=pair<int,int>;i32main(){ ios::sync_with_stdio(false),cin.tie(nullptr); intn,c; ci......
  • python pdf 转图片
    1.需要安装requests,PyMuPDF依赖pipinstallrequests,PyMuPDF。可以通过定义的缩放因子和旋转因子去缩放图片和旋转。#!/usr/bin/envpython3#-*-coding:utf-8-*-importdatetimeimportosimportrequestsimportfitz#fitz就是pipinstallPyMuPDFheaders......
  • Python——量化交易的得力助手
    在当今的金融领域,量化交易正逐渐成为一种重要的交易方式。而在众多编程语言中,Python似乎成为了量化交易的首选,今天我们总结下在量化交易中Python常用的的库和工具。数据处理与分析1.Pandas:这是一个用于数据处理和分析的强大库。在量化交易中,它可以用来读取、清洗和处......
  • PYTHON处理时间数据
    目录模块简介1.datetime模块2.pandas库操作示例datetime模块pandas处理时间序列dateutil解析时间在Python中处理时间数据,你可以使用标准库中的datetime模块,或者使用第三方库如pandas和dateutil。模块简介在Python中处理时间数据,通常会用到datetime模块和pandas库。以下是......
  • 《Python游戏编程入门》注-第3章2
    《Python游戏编程入门》的“3.2.2获取用户输入”部分介绍了input()函数的用法;“3.2.3异常处理”部分介绍了try...except语句的用法。1input()函数的用法input()函数用于接受用户的输入,该函数的参数可以在等待用户输入之前显示文本。该函数主要有两种用法:第一个是将当前程......
  • 《Python游戏编程入门》注-第3章1
    《Python游戏编程入门》的第三章是“I/O、数据和字体:Trivia游戏”,介绍了print()函数、input()函数、异常处理以及文件的输入输出,最后根据以上内容完成了Trivia游戏。本章的“3.1了解Trivia游戏”介绍了Trivia游戏的界面和玩法。“3.2Python数据类型”中讲解了print()函数、i......
  • 基于卷积神经网络的瓶盖状态识别系统,resnet50,mobilenet模型【pytorch框架+python源码
    更多目标检测和图像分类识别项目可看我主页其他文章功能演示:卷积神经网络,瓶盖状态识别系统,resnet50,mobilenet【pytorch框架,python】_哔哩哔哩_bilibili(一)简介基于卷积神经网络的瓶盖状态识别系统是在pytorch框架下实现的,这是一个完整的项目,包括代码,数据集,训练好的模型权重,......
  • flask+python+html+mongodb
     python运行此文件,跳转到index.htmlfromflaskimportFlask,render_template,request,jsonify,json,url_for,redirectapp=Flask(__name__)@app.route('/',methods=['GET','POST'])defindex():returnrender_template('index.......
  • 基于python的足球比赛数据及可视化 python 足球预测
    那么四年一度的世界杯即将要在卡塔尔开幕了,对于不少热爱足球运动的球迷来说,这可是十分难得的盛宴,而对于最后大力神杯的归属,相信很多人都满怀着期待,每个人心中都有不同的答案。软件免费下载:http://lcsjfx.com/SoccerPredictor/DownLoad今天小编就通过Python数据分析以及机器......