这是一道考验思维找规律的题,很有可做性。


正文

题意

一个 n * m 的矩阵,从左上角(1 , 1) 开始,先向下走直到最下方,再向右走到最右,再向上走一个,再走到最左......一直走到(1 , 2)为止

然后问你走完第k步后当前的坐标


分析

正常走然后算是不行的,时间太长,而且还很难写。

既然行走规则是固定的,那我们就试着找一下规律。

我们把行走分成两部分:

  • 第一部分:从(1 , 1)开始一直走到(n ,1)的过程(也就是从左上角走到左下角的过程)。

    这个过程我们可以知道,走完第k步的坐标是(k+1 , 1);

  • 第二部分,从(n ,2)开始走回到(1 , 2)的过程。

    这个过程我们首先可以看出,当走到第 n - i 行时,若 i 是偶数,则是从左向右走,是奇数则相反;

然后问题就转化成了求当前行是从左往右走还是从右往左走,那我们就把 k 截取第二部分的步数,根据 k 与 m-1(因为第一行已经走过) 的商是否为偶数来判断走向,然后根据在当前行走的步数来确定具体走到哪一格;

这样的方法可以确定 y ,那怎么确定 x 呢?

你确定了行数 x 不就出来了吗


代码

ps:注释掉的是我一开始的写法,思路一样但是比较冗余,化简后就是这个亚子了

#include<iostream>
#include<cstdio>
#include<queue>
#include<cstdlib>
#include<cmath>
#define maxn 100010 using namespace std; long long n,m,k,ans,x,y; int main(){
cin>>n>>m>>k;
if(k<n){
cout<<k+1<<" "<<1;
return 0;
}
k=k-n+1;
long long t=(k-1)/(m-1);
long long q=(k-1)%(m-1);
x=n-t;
if(k==0){
cout<<n<<" "<<1;
return 0;
}
// if(q==0 &&t%2!=0){
// y=m;
// cout<<x<<" "<<y;
// return 0;
// }
// if(q==0 &&t%2==0){
// y=2;
// cout<<x<<" "<<y;
// return 0;
// }
if(x%2==0){
y=q+2;
cout<<x<<" "<<y;
// if ( ((t%2)+1)%2==0 ){
// y=m-q+1;
// }
// if ( ((t%2)+1)%2!=0 ){
// y=q+1;
// }
}
else cout<<x<<" "<<m-q;
// cout<<k<<" "<<q<<" "<<t;
return 0;
}

若有问题请及时告知我,制作不易,不喜勿喷,谢谢。

CF976B的更多相关文章

随机推荐

  1. laravel 数据库之DB类

    // 取回数据表的第一条数据 DB::table('table')->where('key', 'value')->first(); DB::table('table')->firs ...

  2. Android驱动入门-在Android系统上运行JAVA程序

    在linux上运行java程序,直接用javac编译,再用java运行就行了.但是在Android上,由于虚拟机和pc端的不同,所以操作方法也是不一样的. 如果想在Android上运行Hello wo ...

  3. 一个轻量级的.Net Core微服务快速开发的轮子

    前言     Adnc是一个轻量级的.Net Core微服务快速开发框架,同时也可以应用于单体架构系统的开发.框架基于JWT认证授权.集成了一系列微服务配套组件,代码简洁.易上手.学习成本低.开箱即用 ...

  4. 循序渐进VUE+Element 前端应用开发(32)--- 手机短信动态码登陆处理

    在一些系统中,有时候用户忘记密码,可以通过向自己手机发送动态验证码的方式实现系统登录功能.本篇随笔介绍如何结合后端ABP框架的短信发送和缓存模块的处理,实现手机短信动态码登陆处理. 一般的登录方式,分 ...

  5. Ubuntu18.04换源

    引用:https://blog.csdn.net/u012308586/article/details/102953882 第一步.sudo  cp   /etc/apt/sources.list  ...

  6. PPT 转 word

    可以wps  直接转 打开wps   在页面里直接点击右键  可以导出wps

  7. TypeLoadException: 未能从程序集“ECS.GUI.Define, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null”中加载类型“ECS.GUI.Define.ArmgAimPos”,因为它在 4 偏移位置处包含一个对象字段,该字段已由一个非对象字段不正确地对齐或重叠

    TypeLoadException: 未能从程序集"ECS.GUI.Define, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null ...

  8. Github美化 添加徽章

    Github美化 添加徽章 0. 前言 1. 准备 2. 开始 a. 打开shields.io b.制作静态徽章 c.制作动态徽章 d. 结果 3.额外 0. 前言 之前看见很多大项目都有很多勋章,比 ...

  9. 当音乐学博士搞起编程,用一本书改变了Java世界!

    前言 说到Spring,也许现在的开发者们最先想到的是 Josh Long 超快的语速与现场代码能力,让很多Java开发者折服. 然后Spring的历史上,最传奇的还是要数其创始人:Rod Johns ...

  10. Openstack Ocata 公共服务端(三)

    Openstack Ocata 公共服务端 mysql 安装: yum install mariadb mariadb-server mysql 安装过程省略 rabbit-server 安装包: # ...