首页 > 其他分享 >[nc 记录] CF13333E Road to 1600

[nc 记录] CF13333E Road to 1600

时间:2023-08-13 19:45:11浏览次数:51  
标签:end int 1600 nc 构造 times -- time CF13333E

赛时没做出来一直在往随机想。

题意挺明确。发现到 \(n \times n\) 这个条件,联想到做过的 CF1172D,递归去掉一行一列的基本想法就有了。

那么让两个棋子从右下开始,走完多出的一行一列,然后走进剩余的 \((n-1) \times (n-1)\)。

真可以?这就是 *2400 的构造?这我还能想不出来?

只用构造 \(3 \times 3\) 的矩阵就行了。zzy 说用

\[\begin{bmatrix} 1 & 3 & 9 \\ 3 & 2 & 5 \\ 4 & 8 & 6 \end{bmatrix} \]

这个矩阵就行了。

整体上思路可以用一句话说完。

事实上,随机数据大多车和后都只用中转 \(1\) 次。此时必须依赖于构造。构造题使用递归还是常见并好做的。一定要记得。

// start time : 
// debug time :
// end time : 
#include <bits/stdc++.h>
const int M = 505;

int a[M][M];

int main() {
  int n; scanf("%d", &n);
  if (n == 1 || n == 2)
    return printf("-1\n"), 0;
  a[1][1] = 1, a[1][2] = 7, a[1][3] = 9;
  a[2][1] = 3, a[2][2] = 2, a[2][3] = 5;
  a[3][1] = 4, a[3][2] = 8, a[3][3] = 6;
  for (int i = 1; i <= 3; i++) 
    for (int j = 1; j <= 3; j++)
      a[i][j] += n * n - 9;
  int cnt = 0;
  for (int i = n; i > 3; i--) {
    if ((n - i) & 1) {
      for (int j = 1; j <= i; j++)
        a[j][i] = ++cnt;
      for (int j = i - 1; j >= 1; j--)
        a[i][j] = ++cnt;
    } else {
      for (int j = 1; j <= i; j++)
        a[i][j] = ++cnt;
      for (int j = i - 1; j >= 1; j--) 
        a[j][i] = ++cnt;
    }
  }
  for (int i = 1; i <= n; i++) {
    for (int j = 1; j <= n; j++) printf("%d ", a[i][j]);
    printf("\n");
  }
  return 0;
}
/*
stupid mistakes:
  - 
*/

标签:end,int,1600,nc,构造,times,--,time,CF13333E
From: https://www.cnblogs.com/purplevine/p/17627090.html

相关文章

  • VSCode C++开发环境配置:CMake 调试配置 launch.json
    相关内容VSCodeC++开发环境配置:LLVMclangclangd安装cmakesudoaptinstallcmake安装VSCode插件CMakeCMakeTools编写CMakeLists.txtproject(hello)cmake_minimum_required(VERSION3.15.0)set(CMAKE_CXX_STANDARD17)set(CMAKE_CXX_EXTENSIONSOFF)add......
  • java opencv在图片上绘制 矩形
    javaopencv在图片上绘制矩形 packagecom.vfsd.core;importorg.opencv.core.Core;importorg.opencv.core.CvType;importorg.opencv.core.Mat;importorg.opencv.core.Point;importorg.opencv.core.Rect;importorg.opencv.core.Scalar;importorg.opencv.highgu......
  • local variable referenced before assignment
    在函数内部更改全局变量就会出现此错误。对于全局变量的修改如果全局变量是int或者str,那么如果想要在函数中对函数变量进行修改,则需要先在函数内,声明其为global,再进行修改如果是list或者dict则可以直接修改摘选:https://blog.csdn.net/weixin_48419914/article/details/12200......
  • M2版Mac mini被京东杀到史低2888元!比苹果官网低1600
    苹果跳水王M2版Macmini又降价了。根据京东官方百亿补贴频道显示,Macmini8+256GB入门版只要2888元了,比前不久的拼多多2959还低,刷新了这款电脑的史上最低价。对比官网原价的4499元,直接跌掉超过1600元,已经非常值得入手。尤其是Macmini对比同价位的Windows迷你机,不论是性能还是......
  • 【RL】L7-Temporal-difference learning
    TDlearningofstatevaluesThedata/experiencerequiredbythealgorithm:\(\left(s_0,r_1,s_1,\ldots,s_t,r_{t+1},s_{t+1},\ldots\right)\)or\(\left\{\left(s_t,r_{t+1},s_{t+1}\right)\right\}_t\)generatedfollowingthegivenpolicy......
  • org.springframework.context.ApplicationContextException: Failed to start bean 'd
    ##    一、报错信息org.springframework.context.ApplicationContextException:Failedtostartbean'documentationPluginsBootstrapper';nestedexceptionisjava.lang.NullPointerException具体报错信息如下:##  二、报错原因     SpringBoot2......
  • 达芬奇 DaVinci Resolve Studio 17.4影视后期调色软件下载和安装教程
    DaVinciResolve是一款专业的调色软件,将专业8K编辑,色彩校正,视觉效果和音频后期制作等功能集于一体的影视后期处理软件。广泛应用在影视后期,栏目包装,宣传片、广告片等领域。软件介绍调色页面设有全新HDR面板,可让您创建自定义色调范围的色轮,以便单独对任何色调范围进行微调!新增的......
  • 38 pinctrl(四)pinctrl driver
    前言一些使用技巧查看设备支持的pinctrlls/sys/kernel/debug/pinctrl/查看pinctrl中支持的引脚、组、functioncat/sys/kernel/debug/pinctrl/20e0000.iomuxc/pinscat/sys/kernel/debug/pinctrl/20e0000.iomuxc/pingroupscat/sys/kernel/debug/pinctrl/20e0000.io......
  • 【RL】CH1-Basic Concepts
    1.7MarkovdecisionprocessesThissectionpresentstheseconceptsinamoreformalwayundertheframeworkofMarkovdecisionprocesses(MDPs).AnMDPisageneralframeworkfordescribingstochasticdynamicalsystems.ThekeyingredientsofanMDParel......
  • 16收16发ARINC429模块
    6通道发送,16通道接收* 发送通道:每路发送通道FIFO大小为:511x32bit(CHR32216/32316),缓存256条发送消息(CHR32216-EX/32316-EX)发送FIFO可设置复位可设置消息间隔,字间隔和发送帧的预定数呈发送波特率100Kbps、50Kbps、48Kbps、12.5Kbps、10Kbps可设置标准ARINC429字格式转换与......