2.模拟问题——3.叠筐

2024-03-04 00:12
文章标签 问题 模拟 叠筐

本文主要是介绍2.模拟问题——3.叠筐,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述
【原题链接】

分析

题目含义

根据题目要求,即要将中心值放在正方形框正中心,然后依次轮换在外层围上另一个边缘值,围的时候边框要保证中心值和边缘值交替,所围图形保持为一个正方形,围完最后一圈后,需要将四个角的值改成空格。

题目要点

  • 输入三元组数目不确定:说明需要使用while+scanf循环来输入
  • 三元组结构为{整数,字符,字符}:说明输入时需要控制赋值给变量,注意类型

题目规律:图案问题:二维数组+数字规律

在这里插入图片描述

  • 中心坐标,n=11时,为(5,5),推得一般式为(n/2,n/2)
  • 四周坐标,n=11时,从0开始计数
    • 第一圈:左上:(5,5);左下(5,5);右上(5,5);右下(5,5);边长为1
    • 第二圈:左上:(4,4);左下(4,6);右上(6,4);右下(6,6);边长为3
    • 第三圈:左上:(3,3);左下(3,7);右上(7,3);右下(7,7);边长为5
    • 显然,若有:
    • 第 k 圈:左上:(m,m);左下(m,h);右上(h,m);右下(h,h);边长为g
    • 则有:
    • 第k+1圈:左上:(m-1,m-1);左下(m-1,h+1);右上(h+1,m-1);右下(h+1,h+1);边长为g+2

代码

#include <cstdio>
int main() {int n;//外框围数char inner,outer;//中心值和边缘值while(scanf("%d %c %c", &n, &inner, &outer) != EOF){//scanf %d %f %o 忽略空白字符//scanf %c 可以读取空白字符,即可以读取空格和换行等//scanf %c 如果%c前面有空格,则可以忽略空白字符
//        printf("n = %d, inner = %c, outter = %c n",n,inner,outer);char pattern[80][80] = {0};//二维数组长度要固定,避免麻烦//在定义二维数组时,可以初始化,如上面这条代码,char数组内全部是0int init = n/2;//第一圈的中心int length;//外框的长度int x,y;//坐标char currentChar = inner;for (length = 1, x = init, y = init; length <= n; length+=2, --x, --y) {//xy是起点的下标,每次循环都要填满一个长度为length的正方形for (int i = x, j = y; i < x+length; ++i) {//j不变,i从x到x+length-1pattern[i][j] = currentChar;}for (int i = x, j = y; j < y+length; ++j) {//i不变,j从y到y+length-1pattern[i][j] = currentChar;}for (int i = x+length-1, j=y; j < y+length; ++j) {pattern[i][j] = currentChar;}for (int i = x, j=y+length-1; i < x+length; ++i) {pattern[i][j] = currentChar;}if (currentChar == inner){currentChar = outer;}else{currentChar = inner;}}//抹掉四角if (n != 1){pattern[0][0]=' ';pattern[n-1][0]=' ';pattern[0][n-1]=' ';pattern[n-1][n-1]=' ';}for (int i = 0; i < n; ++i) {printf("%s\n",pattern[i]);}printf("\n");//没有这句会报Presentation Error}return 0;
}

OJ系统中常见的错误类型

  • Wrong Answer:思路有问题,未考虑周全
  • Accepted:正确
  • Compilation Error:编译出错,代码语法等出现问题
  • Presentation Error:表示错误,换行、输出格式有问题,距离Accepted一步之遥

这篇关于2.模拟问题——3.叠筐的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

Pyserial设置缓冲区大小失败的问题解决

《Pyserial设置缓冲区大小失败的问题解决》本文主要介绍了Pyserial设置缓冲区大小失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录问题描述原因分析解决方案问题描述使用set_buffer_size()设置缓冲区大小后,buf

resultMap如何处理复杂映射问题

《resultMap如何处理复杂映射问题》:本文主要介绍resultMap如何处理复杂映射问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录resultMap复杂映射问题Ⅰ 多对一查询:学生——老师Ⅱ 一对多查询:老师——学生总结resultMap复杂映射问题

java实现延迟/超时/定时问题

《java实现延迟/超时/定时问题》:本文主要介绍java实现延迟/超时/定时问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java实现延迟/超时/定时java 每间隔5秒执行一次,一共执行5次然后结束scheduleAtFixedRate 和 schedu

如何解决mmcv无法安装或安装之后报错问题

《如何解决mmcv无法安装或安装之后报错问题》:本文主要介绍如何解决mmcv无法安装或安装之后报错问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mmcv无法安装或安装之后报错问题1.当我们运行YOwww.chinasem.cnLO时遇到2.找到下图所示这里3.

浅谈配置MMCV环境,解决报错,版本不匹配问题

《浅谈配置MMCV环境,解决报错,版本不匹配问题》:本文主要介绍浅谈配置MMCV环境,解决报错,版本不匹配问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录配置MMCV环境,解决报错,版本不匹配错误示例正确示例总结配置MMCV环境,解决报错,版本不匹配在col

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

SpringBoot首笔交易慢问题排查与优化方案

《SpringBoot首笔交易慢问题排查与优化方案》在我们的微服务项目中,遇到这样的问题:应用启动后,第一笔交易响应耗时高达4、5秒,而后续请求均能在毫秒级完成,这不仅触发监控告警,也极大影响了用户体... 目录问题背景排查步骤1. 日志分析2. 性能工具定位优化方案:提前预热各种资源1. Flowable