开灯问题 —— POJ 1218 THE DRUNK JAILER

2024-09-05 04:08
文章标签 问题 poj 开灯 1218 drunk jailer

本文主要是介绍开灯问题 —— POJ 1218 THE DRUNK JAILER,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

对应POJ 题目:点击打开链接

THE DRUNK JAILER
Time Limit: 1000MS Memory Limit: 10000K
Total Submissions: 24831 Accepted: 15569

Description

A certain prison contains a long hall of n cells, each right next to each other. Each cell has a prisoner in it, and each cell is locked. 
One night, the jailer gets bored and decides to play a game. For round 1 of the game, he takes a drink of whiskey,and then runs down the hall unlocking each cell. For round 2, he takes a drink of whiskey, and then runs down the 
hall locking every other cell (cells 2, 4, 6, ?). For round 3, he takes a drink of whiskey, and then runs down the hall. He visits every third cell (cells 3, 6, 9, ?). If the cell is locked, he unlocks it; if it is unlocked, he locks it. He 
repeats this for n rounds, takes a final drink, and passes out. 
Some number of prisoners, possibly zero, realizes that their cells are unlocked and the jailer is incapacitated. They immediately escape. 
Given the number of cells, determine how many prisoners escape jail.

Input

The first line of input contains a single positive integer. This is the number of lines that follow. Each of the following lines contains a single integer between 5 and 100, inclusive, which is the number of cells n. 

Output

For each line, you must print out the number of prisoners that escape when the prison has n cells. 

Sample Input

2
5
100

Sample Output

2
10

题意:

可以理解成这样:有n盏灯,一开始所有灯都是灭的,第1轮对序号是1的倍数的灯操作(原来亮的就熄灭,原来灭的就点亮);第2轮对序号是2的倍数的灯操作、、、第i轮对序号是i的倍数的灯操作,直到第n轮过后,问剩下多少盏灯是亮的。


思路1:枚举,不解释


思路2:

这个问题有如下性质:

1、如果某盏灯被操作的次数是奇数,那它就是亮的(一开始是灭的)。

2、对于第i盏灯(i从1开始),如果i是完全平方数,那这盏灯被操作的次数就是奇数。


性质1是显然的:第0次是灭的,第1次是亮的,第2次是灭的。。。

性质2的证明:

对于序号为18这盏灯,它被操作的轮数是:第1轮,第2轮,第3轮,第6轮,第9轮,第18轮。被操作了6次,是偶数次。它被操作的轮数其实就是它的所有约数。一个大于1的非完全平方数的约数个数都是成对出现的,即都是偶数。而完全平方数,如16,其约数为1,2,4,8,16。是5个,因为4的平方是16,所以4只算一次。所以完全平方数的约数是奇数。


对于题目要求,序号为i的灯的被操作次数就是i的所有约数的个数a,如果a是奇数,那序号为i的灯最后就是亮的。归结起来就是如果i是完全平方数,那序号为i的灯最后就是亮的。所以题目最后求的就是1~n的完全平方数的个数。答案不难得出,就是将n开方向下取整(可以这样理解:x^2 <= n,解出x = 根号n向下取整,那x就是满足要求的最大值,如果k属于1~x,那k^2都是完全平方数,共有x个)。


思路1代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define M 550
int a[M];int main()
{//freopen("in.txt","r",stdin);int n, x, i, j, ans;scanf("%d", &n);while(n--){ans = 0;memset(a, 0, sizeof(a));scanf("%d", &x);for(i = 1; i <= x; i++){for(j = i; j <= x; j += i){if(a[j]) a[j] = 0;else a[j] = 1;}}for(i = 1; i <= x; i++)if(a[i]) ans++;printf("%d\n", ans);}return 0;
}

思路2代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>int main()
{//freopen("in.txt","r",stdin);int n, x;scanf("%d", &n);while(n--){scanf("%d", &x);printf("%d\n", (int)sqrt(double(x)));}return 0;
}

两种写法的空间都是140k左右,时间都是0ms,不太理解~






这篇关于开灯问题 —— POJ 1218 THE DRUNK JAILER的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

mybatis和mybatis-plus设置值为null不起作用问题及解决

《mybatis和mybatis-plus设置值为null不起作用问题及解决》Mybatis-Plus的FieldStrategy主要用于控制新增、更新和查询时对空值的处理策略,通过配置不同的策略类型... 目录MyBATis-plusFieldStrategy作用FieldStrategy类型每种策略的作

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

pip install jupyterlab失败的原因问题及探索

《pipinstalljupyterlab失败的原因问题及探索》在学习Yolo模型时,尝试安装JupyterLab但遇到错误,错误提示缺少Rust和Cargo编译环境,因为pywinpty包需要它... 目录背景问题解决方案总结背景最近在学习Yolo模型,然后其中要下载jupyter(有点LSVmu像一个

解决jupyterLab打开后出现Config option `template_path`not recognized by `ExporterCollapsibleHeadings`问题

《解决jupyterLab打开后出现Configoption`template_path`notrecognizedby`ExporterCollapsibleHeadings`问题》在Ju... 目录jupyterLab打开后出现“templandroidate_path”相关问题这是 tensorflo

如何解决Pycharm编辑内容时有光标的问题

《如何解决Pycharm编辑内容时有光标的问题》文章介绍了如何在PyCharm中配置VimEmulator插件,包括检查插件是否已安装、下载插件以及安装IdeaVim插件的步骤... 目录Pycharm编辑内容时有光标1.如果Vim Emulator前面有对勾2.www.chinasem.cn如果tools工

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

Java多线程父线程向子线程传值问题及解决

《Java多线程父线程向子线程传值问题及解决》文章总结了5种解决父子之间数据传递困扰的解决方案,包括ThreadLocal+TaskDecorator、UserUtils、CustomTaskDeco... 目录1 背景2 ThreadLocal+TaskDecorator3 RequestContextH

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

关于最长递增子序列问题概述

《关于最长递增子序列问题概述》本文详细介绍了最长递增子序列问题的定义及两种优化解法:贪心+二分查找和动态规划+状态压缩,贪心+二分查找时间复杂度为O(nlogn),通过维护一个有序的“尾巴”数组来高效... 一、最长递增子序列问题概述1. 问题定义给定一个整数序列,例如 nums = [10, 9, 2