开灯问题 c++

2023-12-26 14:08
文章标签 c++ 问题 开灯

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

注:如果觉得有问题,可以一起讨论哦

 问题:有n盏灯,编号为1~n,第一个人把所有的灯打开,第二个人按下所有编号为2的倍数的开关(这些灯将被关掉),第三个人按下所有编号为3的倍数的开关(期中关掉的将被打开,打开的将被关掉)依此类推,一共有k个人,问最后有哪些灯开着,输入n和k,输出开着的灯的编号。k<=n<=1000

样例输入:

7 3

样例输出:

1 5 6 7


【分析】:用数组flag[],flag[0],flag[1],flag[2]....flag[n]表示灯1,2,3.。。。n是否开着。首先将他们全置为0,表示他们都开着,1则表示关了灯。

用例子来分析,7盏灯,3个人


因为flag[i]是会动态改变的,所以解题关键就是如何动态的去改变flag[i]的值

由图所见它和((i+1)%j==0)有关,如果i能整除j,那么flag[i]原来的值就要改变。

假设int a=((i+1)%j==0))=1

当j=2时,flag[2]由0变为1,flag[4]由0变为1,flag[6]由0变为1

当j=3时,flag[3]由0变为1,flag[6]由1变为0。

flag[i]到底和a有着什么样的关系?不难想象,他们是异或关系。

即flag[i]=((i+1)%j) xor flag[i]。

那我们要怎么样在代码中表示异或呢?

我们除了要判断i是否整除j,还要判断它是否和flag[i]的值是否一样,如果不一样,flag[i]就置1。

为了结果之间加空格,所以加了一个变量d,第一个结果肯定不能有空格,所以初始化d=0;当d=0时,不输出空格。d不等于0,就输出空格。

输入第一个结果后,d++;


所以代码很简单

       

                    /**开灯问题**/#include "stdafx.h"
#include <string.h>
#define maxn 1010
int flag[maxn];
int _tmain(int argc, _TCHAR* argv[])
{int n,k,d=0;scanf("%d%d",&n,&k);for(int i=0;i<n;i++){flag[i]=0;//打开//printf("%d\n",flag[i]);for(int j=2;j<=k;j++){if((i+1)%j==0){if(((i+1)%j==0)==flag[i])flag[i]=0;else flag[i]=1;}//printf("%d[%d]:%d\n",j,i,flag[i]);}//结果之间加空格   if(flag[i]==0){if(d==0){printf("%d",i+1);d++;}else printf(" %d",i+1);}}printf("\n");return 0;
}


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



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

相关文章

解决hive启动时java.net.ConnectException:拒绝连接的问题

《解决hive启动时java.net.ConnectException:拒绝连接的问题》Hadoop集群连接被拒,需检查集群是否启动、关闭防火墙/SELinux、确认安全模式退出,若问题仍存,查看日志... 目录错误发生原因解决方式1.关闭防火墙2.关闭selinux3.启动集群4.检查集群是否正常启动5.

idea Maven Springboot多模块项目打包时90%的问题及解决方案

《ideaMavenSpringboot多模块项目打包时90%的问题及解决方案》:本文主要介绍ideaMavenSpringboot多模块项目打包时90%的问题及解决方案,具有很好的参考价值,... 目录1. 前言2. 问题3. 解决办法4. jar 包冲突总结1. 前言之所以写这篇文章是因为在使用Mav

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

C++中detach的作用、使用场景及注意事项

《C++中detach的作用、使用场景及注意事项》关于C++中的detach,它主要涉及多线程编程中的线程管理,理解detach的作用、使用场景以及注意事项,对于写出高效、安全的多线程程序至关重要,下... 目录一、什么是join()?它的作用是什么?类比一下:二、join()的作用总结三、join()怎么

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束