CF1487 Cat Cycle
一个规律题目要多做多积累 , 脑子不太灵活
题目大意:
两只猫A,B, A猫从n -> n-1 -> n-2 ... -> 1 -> 2 ... -> n ; B猫从1 -> 2 -> ... -> n -> n-1 -> ... -> 1
当两猫要相遇时,B猫往所移动得方向+1,而A猫占在相遇的位置上 (题目里面说A猫比B猫大,所以要让座...) .
输入: n为位置长度,k为第k小时 .
输出: 第k时,b猫所在得位置(数字).
思路:
整体而言,就是要知道B猫在k小时内一共移动了多少次,再将移动次数与n直接取模就是答案。
1.显然当n为偶数的时候,两者不可能相遇,将 移动次数 与n直接取模即可 (题目中k为第k小时,所以整体移动次数是k-1次)
2.当n为奇数的时候,在一个n的周期内,没相遇之前两者每移动一次都增加1,由于n为奇数,所以在移动n/2次时,就绝对会相遇一次,这时B猫就多走了一次。
也就是说,在一共移动k-1次中,每n/2次时B猫要多走一部,所以总的移动次数就是原来的再加上增加的,最后于n取模就是答案
代码如下:
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<string>
#include<cstring>
#include<algorithm>
#include<vector>
#include<map>
#define ri register int
#define ll int
#define lll long long
using namespace std;
ll n,k;
ll t;
int main()
{
	ios::sync_with_stdio(0);
	cout.tie(0),cin.tie(0);
	cin>>t;
	while(t--)
	{
		cin>>n>>k;
		if(n&1)
		{
			ll mr=n>>1;   //每n/2增加一次
			mr=(k-1)/mr;  //所以移动k-1次要增加(k-1)/(n/2) 次
			k+=mr;        //此时k为B猫一共移动次数
			ll ans=(k-1)%n;  //取模完事
			cout<<++ans<<"\n";
		}
		else
		{
			ll ans=(k-1)%n;   // k-1 为移动次数
			cout<<++ans<<"\n";
		}
	}
	return 0;
}
写的溜的一批,自己就想不到
CF1487 Cat Cycle的更多相关文章
- 【Ansible】ansible循环
		
Ansible 循环 一.简单介绍 在ansible2.5之前,大多数人使”with_XXX”类型的关键字来操作循环,但是从2.6版本开始,官方推荐是”loop”关键字代替” with_XXX”. 1 ...
 - Ansible自动化运维应用实战
		
实验环境 centos7.4 主机名称 IP 配置 用途 controlnode 172.16.1.120 1核/1G/60G ansible slavenode1 172.16.1.121 1核/1 ...
 - 单细胞数据高级分析之消除细胞周期因素 | Removal of cell cycle effect
		
The normalization method described above aims to reduce the effect of technical factors in scRNA-seq ...
 - shell more less cat
		
cat 连续显示.查看文件内容 more 分页查看文件内容 less 分页可控制查看文件内容 通俗点说: cat一次性把文件内容全部显示出来,管你看不看得清,显示完了cat命令就返回了,不能进行交互式 ...
 - 使用JSONObject.fromObject的时候出现“There is a cycle in the hierarchy”异常 的解决办法
		
在使用JSONObject.fromObject的时候,出现“There is a cycle in the hierarchy”异常. 意思是出现了死循环,也就是Model之间有循环包含关系: ...
 - JS案例之2——cycle元素轮播
		
元素轮播效果是页面中经常会使用的一种效果.这个例子实现了通过元素的隐藏和显示来表现轮播效果.效果比较简单. 效果图如下: 源代码如下: <!DOCTYPE html> <html&g ...
 - 基于Cat的分布式调用追踪
		
Cat是美团点评出的一款APM工具,同类的产品也有不少,知名的开源产品如zipkin和pinpoint:国内收费的产品如oneapm.考虑到Cat在互联网公司的应用比较广,因此被纳入选型队列,我也有幸 ...
 - mkdir,rmdir,cp,rm,mv,cat,touch用法
		
一.mkdir新建目录 1.进入tmp目录,查看该目录下面的子目录 [root@localhost ~]# cd /tmp[root@localhost tmp]# lshsperfdata_root ...
 - 大众点评cat系统的搭建笔记
		
项目地址:https://github.com/dianping/cat 编译步骤: 这个项目比较另类,把编译需要的jar包,单独放在git分支mvn-repo里了,而且官方文档里给了一个错误的命令提 ...
 
随机推荐
- ch1_6_5求解旋转词问题
			
import java.util.Scanner; public class ch1_6_5求解旋转词问题 { public static void main(String[] args) { // ...
 - Centos7安装以及设置Redis详细步骤
			
一.Redis安装: 1.指定文件夹下下载redis安装包: [root@bogon ~]# mkdir /usr/local/soft/redis [root@bogon ~]# cd /usr/l ...
 - Spring的循环依赖
			
本文简要介绍了循环依赖以及Spring解决循环依赖的过程 一.定义 循环依赖是指对象之间的循环依赖,即2个或以上的对象互相持有对方,最终形成闭环.这里的对象特指单例对象. 二.表现形式 对象之间的循环 ...
 - Python fire库使用
			
1.前要fire是python中用于生成命令行界面(Command Line Interfaces, CLIs)的工具 不需要做任何额外的工作,只需要从主模块中调用fire.Fire() 它会自动将你 ...
 - Spring Boot 轻量替代框架 Solon 1.3.20 发布
			
Solon 是一个微型的Java开发框架.项目2018年启动,参考过大量前人作品:内核0.1m的身材,超高的跑分,以及良好的使用体验.支持:RPC.REST API.MVC.WebSocket.Soc ...
 - Mybatis-plus 下
			
Mybatis-plus 下 查询操作 1.查询单个用户 @Test public void testSelectById(){ User user = userMapper.selectById(1 ...
 - 体渲染——Volume
			
基本概念 体渲染(Volume),是绘制类似烟.雾.云的效果.这种渲染和之前的表面渲染不同,光线可以在物体内部进行散射. 体渲染的主要特点 1. 可以在物体内部散射. 2. 从进入vo ...
 - CentOS更换aliyun镜像站
			
目录 1. 官方地址 2. 社区文档 3. 镜像更换 3.1 配置方法: 3.1.1. 备份原配置文件 3.1.2. 下载新的 CentOS-Base.repo 到 /etc/yum.repos.d/ ...
 - 横趟!面试中遇到的 ZooKeeper 问题
			
本文作者:HelloGitHub-老荀 本文是 HelloZooKeeper 系列的最后一篇文章,接下来主要聊聊面试中如果被问到 ZooKeeper 的问题如何回答,也可以当作学完本系列的测试. 准备 ...
 - Java多线程编程(同步、死锁、生产消费者问题)
			
Java多线程编程(同步.死锁.生产消费): 关于线程同步以及死锁问题: 线程同步概念:是指若干个线程对象并行进行资源的访问时实现的资源处理保护操作: 线程死锁概念:是指两个线程都在等待对方先完成,造 ...