当前位置: 首页 > news >正文

C语言/C++自然序列重排列——相邻序号不相邻问题⭐

同类题目:C语言自然序列重排——相邻元素的差值集合恰好有 k 个不同的值。⭐⭐-CSDN博客

题目描述(难度⭐)

一场针对 n 学生的考试将在一个又长又窄的房间里举行,因此学生们将按某种顺序排成一行。老师怀疑相邻编号的学生(i 和 i + 1)总是坐在一起学习,并成为朋友,如果他们在考试时坐在一起,他们肯定会互相帮助。 你的任务是选择最大数量的学生,并安排这些学生在教室里坐下,使得没有两个相邻编号的学生坐在一起。

输入

单独的一行包含一个整数 n(1 ≤ n ≤ 5000)— 考试中的学生数量。

输出

在第一行打印整数 k — 可以就坐的最大学生数量,使得没有两个相邻编号的学生坐在一起。 在第二行打印 k 个不同的整数 a1, a2, ..., ak(1 ≤ ai ≤ n),其中 ai 是第 i 个位置上的学生编号。相邻位置的学生不能有相邻的编号。

具体来说,对于从 1 到 k - 1 的所有 i,应该满足下面的条件:|ai - ai + 1| ≠ 1。 如果存在多个可能的答案,则输出其中任意一个。

如果存在多个可能的答案,则输出其中任意一个。 

样例输入

6

样例输出

6
1 5 3 6 2 4

 样例输入

3

样例输出

2

1 3


解题思路:通过特殊处理n≤3的情况,以及对n>3的情况根据n的奇偶性分别安排学生座位,使得没有两个相邻编号的学生坐在一起,同时尽量安排最多数量的学生。 

具体思路

1.处理n≤3的特殊情况:

◦ 当n=1时,只有1个学生,直接输出1个学生,编号为1。

◦ 当n=2时,有2个学生,只能选择1个学生,输出1个学生,编号为1。

◦ 当n=3时,有3个学生,可以选择2个学生,输出2个学生,编号为1和3。  

2. 处理n>3的一般情况:

◦ 定义一个数组arr,用于存储学生的编号,数组大小为n+1,将学生的编号1到n依次存储到数组中。

◦ 当n为偶数时:

        ■ 可以安排所有n个学生坐下。输出学生数量n。

        ■ 通过循环,依次输出编号为i+n/2和i的学生(i从1到n/2),这样就能保证相邻编号的                学生不会坐在一起。在输出时,注意最后一个学生编号后面不加空格,直接换行。  

◦ 当n为奇数时:

        ■ 也可以安排所有n个学生坐下。输出学生数量n。

        ■ 通过循环,依次输出编号为i+n/2和i的学生(i从1到n/2),这样就能保证相邻编号的                学生不会坐在一起。

        ■ 最后单独输出编号为n的学生。 

代码实现 (C语言版)


#include <stdio.h>int main() {int n;scanf("%d",&n);  // 输入学生总数n// 处理n≤3的特殊情况if(n<=3){// 当只有1个学生时,直接输出1个学生,编号为1if(n==1) printf("1\n1\n");// 当有2个学生时,只能选择1个学生,输出1个学生,编号为1if(n==2) printf("1\n1\n");// 当有3个学生时,可以选择2个学生,输出2个学生,编号为1和3if(n==3) printf("2\n1 3\n");return 0;  // 结束程序}int arr[n+1];  // 定义一个数组存储学生的编号// 将学生的编号1到n依次存储到数组中for(int i=1;i<=n;i++){arr[i]=i;}// 当n为偶数时,2*(n/2)=nif(n%2==0){printf("%d\n",n);  // 可以安排所有n个学生坐下,输出学生数量n// 通过循环,依次输出编号为i+n/2和i的学生(i从1到n/2)for(int i=1;i<=n/2;i++){// 如果不是最后一个学生对,输出编号后加空格if(i!=n/2)printf("%d %d ",arr[i+n/2],arr[i]);// 如果是最后一个学生对,输出编号后直接换行elseprintf("%d %d\n",arr[i+n/2],arr[i]);}}// 当n为奇数时,2*(n/2)=n-1else{printf("%d\n",n);  // 也可以安排所有n个学生坐下,输出学生数量n// 通过循环,依次输出编号为i+n/2和i的学生(i从1到n/2)for(int i=1;i<=n/2;i++){printf("%d %d ",arr[i+n/2],arr[i]);} printf("%d\n",arr[n]);  // 最后单独输出编号为n的学生}return 0;
}

(C++版) 

#include <iostream>
#include <vector>int main() {int n;std::cin >> n;  // 输入学生总数n// 处理n≤3的特殊情况if(n <= 3) {// 当只有1个学生时,直接输出1个学生,编号为1if(n == 1) std::cout << "1\n1\n";// 当有2个学生时,只能选择1个学生,输出1个学生,编号为1else if(n == 2) std::cout << "1\n1\n";// 当有3个学生时,可以选择2个学生,输出2个学生,编号为1和3else if(n == 3) std::cout << "2\n1 3\n";return 0;  // 结束程序}std::vector<int> arr(n);  // 定义一个vector存储学生的编号// 将学生的编号1到n依次存储到vector中for(int i = 0; i < n; i++) {arr[i] = i + 1;}// 当n为偶数时if(n % 2 == 0) {std::cout << n << std::endl;  // 可以安排所有n个学生坐下,输出学生数量n// 通过循环,依次输出编号为i+n/2和i的学生(i从1到n/2)for(int i = 0; i < n / 2; i++) {// 如果不是最后一个学生对,输出编号后加空格if(i != n / 2 - 1)std::cout << arr[i + n / 2] << " " << arr[i] << " ";// 如果是最后一个学生对,输出编号后直接换行elsestd::cout << arr[i + n / 2] << " " << arr[i] << std::endl;}}// 当n为奇数时else {std::cout << n << std::endl;  // 也可以安排所有n个学生坐下,输出学生数量n// 通过循环,依次输出编号为i+n/2和i的学生(i从1到n/2)for(int i = 0; i < n / 2; i++) {std::cout << arr[i + n / 2] << " " << arr[i] << " ";} std::cout << arr[n - 1] << std::endl;  // 最后单独输出编号为n的学生}return 0;
}

 法二(更巧妙)

代码思路:根据输入的整数 n,输出一个特定的序列:当 n <= 2 时输出 1 1,当 n == 3 时输出 2 1 3,当 n > 3 时先输出 n,然后依次输出所有偶数和奇数。

代码一(时间复杂度O(n))

#include<bits/stdc++.h>
using namespace std;int main() {int n;cin >> n;  // 读取输入的整数 n// 处理 n <= 2 的情况if (n <= 2) {cout << 1 << endl;  // 输出 1cout << 1;        // 输出 1}// 处理 n == 3 的情况else if (n == 3) {cout << 2 << endl;  // 输出 2cout << 1 << " " << 3;  // 输出 1 3}// 处理 n > 3 的情况else {cout << n << endl;  // 输出 n// 输出所有偶数for (int i = 2; i <= n; i += 2) {cout << i << " ";}// 输出所有奇数for (int i = 1; i <= n; i += 2) {cout << i << " ";}}return 0;
}

代码二(时间复杂度为O(2*n)) 

#include<bits/stdc++.h>
using namespace std;int main() {int n;cin >> n;  // 读取输入的整数 n// 处理 n <= 3 的特殊情况if (n <= 3) {// 如果 n <= 2,输出 1 1if (n <= 2) {cout << 1 << endl << 1;}// 如果 n == 3,输出 2 1 3else {cout << 2 << endl << 1 << " " << 3;}return 0;  // 结束程序}// 创建一个大小为 n 的向量 arr,并初始化为 1, 2, 3, ..., nvector<int> arr(n);for (int i = 0; i < n; i++) {arr[i] = i + 1;}// 输出 ncout << n << endl;// 必须先输出奇数,再输出偶数// 先输出偶数再输出奇数会有特例,例如 n = 4 时,输出 2 4 1 3,不符合条件// 先输出奇数for (int i = 1; i < n; i += 2) {cout << arr[i] << " ";}// 再输出偶数for (int i = 0; i < n; i += 2) {cout << arr[i] << " ";}return 0;  // 结束程序
}

相关文章:

C语言/C++自然序列重排列——相邻序号不相邻问题⭐

同类题目&#xff1a;C语言自然序列重排——相邻元素的差值集合恰好有 k 个不同的值。⭐⭐-CSDN博客 题目描述&#xff08;难度⭐&#xff09; 一场针对 n 学生的考试将在一个又长又窄的房间里举行&#xff0c;因此学生们将按某种顺序排成一行。老师怀疑相邻编号的学生&#xf…...

Spring boot面试题---- Spring boot项目运行原理

1.启动流程概述 Spring Boot 的启动是从一个带有main方法的主类开始的。这个主类通常会有一个@SpringBootApplication注解。这个注解是一个组合注解,它包含了@Configuration、@EnableAutoConfiguration和@ComponentScan。@Configuration注解表明这个类是一个配置类,它可以定义…...

Qt/C++ 基于 QGraphicsView 的绘图软件 (附源码下载链接)

基于 Qt 的 QGraphicsView 绘图软件项目进行深入讲解&#xff0c;分析其核心代码与功能实现&#xff0c;帮助开发者理解 QGraphicsView 的用法。 项目概览 该项目实现了一个简单的绘图应用&#xff0c;用户可以在界面中创建和编辑矩形、椭圆、直线、多边形和文本等图形对象。功…...

如何使用 useMemo 和 memo 优化 React 应用性能?

使用 useMemo 和 memo 优化 React 应用性能 在构建复杂的 React 应用时&#xff0c;性能优化是确保应用流畅运行的关键。React 提供了多种工具来帮助开发者优化组件的渲染和计算逻辑&#xff0c;其中 useMemo 和 memo 是两个非常有用的 Hook。本文将详细介绍这两个工具的使用方…...

数据结构(链表 哈希表)

在Python中&#xff0c;链表和哈希表都是常见的数据结构&#xff0c;可以用来存储和处理数据。 链表是一种线性数据结构&#xff0c;由一系列节点组成&#xff0c;每个节点包含一个数据元素和一个指向下一个节点的指针。链表可以用来实现栈、队列以及其他数据结构。Python中可…...

人工智能之深度学习_[4]-神经网络入门

神经网络基础 1 神经网络 深度学习神经网络就是大脑仿生&#xff0c;数据从输入到输出经过一层一层的神经元产生预测值的过程就是前向传播&#xff08;也叫正向传播&#xff09;。 前向传播涉及到人工神经元是如何工作的&#xff08;也就是神经元的初始化、激活函数&#xf…...

STM32之CubeMX图形化工具开发介绍(十七)

STM32F407 系列文章 - STM32CubeMX&#xff08;十七&#xff09; 目录 前言 一、CubeMX 二、下载安装 1.下载 2.安装 3.图解步骤 三、用户界面 1.项目配置 2.项目生成 3.项目文件解释 4.新建工程 5.查看原工程 四、FAQ 总结 前言 STMCube源自意法半导体&#xf…...

css3过渡总结

一、过渡的定义与作用 CSS3 过渡&#xff08;Transitions&#xff09;允许 CSS 属性在一定的时间区间内平滑地过渡&#xff0c;从一个值转变为另一个值。它能够让网页元素的状态变化更加自然、流畅&#xff0c;给用户带来更好的视觉体验。例如&#xff0c;当一个元素从隐藏状态…...

latin1_swedish_ci(latin1 不支持存储中文、日文、韩文等多字节字符)

文章目录 1、SHOW TABLE STATUS WHERE Name batch_version;2、latin1_swedish_ci使用场景注意事项修改字符集和排序规则修改表的字符集和排序规则修改列的字符集和排序规则修改数据库的默认字符集和排序规则 3、ALTER TABLE batch_version CONVERT TO CHARACTER SET utf8mb4 C…...

C语言编程笔记:文件处理的艺术

大家好&#xff0c;这里是小编的博客频道 小编的博客&#xff1a;就爱学编程 很高兴在CSDN这个大家庭与大家相识&#xff0c;希望能在这里与大家共同进步&#xff0c;共同收获更好的自己&#xff01;&#xff01;&#xff01; 本文目录 引言正文一、为什么要用文件二、文件的分…...

[创业之路-255]:《华为数字化转型之道》-1-主要章节、核心内容、核心思想

目录 前言&#xff1a;数字化转型对于企业而言&#xff0c;是一种全方位的变革 一、主要章节 1、认知篇&#xff08;第1~2章&#xff09;- Why 2、方法篇&#xff08;第3~5章&#xff09;- How 3、实践篇&#xff08;第6~10章&#xff09;- 实践 4、平台篇&#xff08;第…...

《汽车维修技师》是什么级别的期刊?是正规期刊吗?能评职称吗?

​问题解答&#xff1a; 问&#xff1a;《汽车维修技师》是不是核心期刊&#xff1f; 答&#xff1a;不是&#xff0c;是知网收录的正规学术期刊。 问&#xff1a;《汽车维修技师》级别&#xff1f; 答&#xff1a;省级。主管单位&#xff1a;北方联合出版传媒&#xff08;…...

2024 京东零售技术年度总结

每一次回望&#xff0c;都为了更好地前行。 2024 年&#xff0c;京东零售技术在全面助力业务发展的同时&#xff0c;在大模型应用、智能供应链、端技术、XR 体验等多个方向深入探索。京东 APP 完成阶段性重要改版&#xff0c;打造“又好又便宜”的优质体验&#xff1b;国补专区…...

PyTorch使用教程(8)-一文了解torchvision

一、什么是torchvision torchvision提供了丰富的功能&#xff0c;主要包括数据集、模型、转换工具和实用方法四大模块。数据集模块内置了多种广泛使用的图像和视频数据集&#xff0c;如ImageNet、CIFAR-10、MNIST等&#xff0c;方便开发者进行训练和评估。模型模块封装了大量经…...

如何在不暴露MinIO地址的情况下,用Spring Boot与KKFileView实现文件预览

在现代Web应用中&#xff0c;文件预览是一项常见且重要的功能。它允许用户在不上传或下载文件的情况下&#xff0c;直接在浏览器中查看文件内容。然而&#xff0c;直接将文件存储服务&#xff08;如MinIO&#xff09;暴露给前端可能会带来安全风险。本文将介绍如何在不暴露MinI…...

ICMP协议和ICMP重定向攻击

✍作者&#xff1a;柒烨带你飞 &#x1f4aa;格言&#xff1a;生活的情况越艰难&#xff0c;我越感到自己更坚强&#xff1b;我这个人走得很慢&#xff0c;但我从不后退。 &#x1f4dc;系列专栏&#xff1a;网络安全从菜鸟到飞鸟的逆袭 目录 一&#xff0c;ICMP基本概念二&…...

leetcode203-移除链表元素

leetcode203 什么是链表 之前不懂链表的数据结构&#xff0c;一看到链表的题目就看不明白 链表是通过next指针来将每个节点连接起来的&#xff0c;题目中给的链表是单向链表&#xff0c;有两个值&#xff0c;一个val表示值&#xff0c;一个next&#xff1a;表示连接的下一个…...

Rust 中构建 RESTful API

在 Rust 中构建 RESTful API&#xff0c;你可以选择几个不同的框架。每个框架有不同的特点、优缺点和适用场景&#xff0c;下面我将介绍几个常用的 Rust Web 框架&#xff0c;并分析它们的优缺点。 Actix Web 简介&#xff1a; Actix Web 是一个非常高性能的 Web 框架&#xf…...

Sqlmap入门

原理 在owasp发布的top10 漏洞里面&#xff0c;注入漏洞一直是危害排名第一&#xff0c;其中数据库注入漏洞是危害的。 当攻击者发送的sql语句被sql解释器执行&#xff0c;通过执行这些恶意语句欺骗数据库执行&#xff0c;导致数据库信息泄漏 分类 按注入类型 常见的sql注入…...

迈向 “全能管家” 之路:机器人距离终极蜕变还需几步?

【图片来源于网络&#xff0c;侵删】 这是2024年初Figure公司展示的人形机器人Figure 01&#xff0c;他可以通过观看人类的示范视频&#xff0c;在10小时内经过训练学会煮咖啡&#xff0c;并且这个过程是完全自主没有人为干涉的&#xff01; 【图片来源于网络&#xff0c;侵删】…...

Vue记事本应用实现教程

文章目录 1. 项目介绍2. 开发环境准备3. 设计应用界面4. 创建Vue实例和数据模型5. 实现记事本功能5.1 添加新记事项5.2 删除记事项5.3 清空所有记事 6. 添加样式7. 功能扩展&#xff1a;显示创建时间8. 功能扩展&#xff1a;记事项搜索9. 完整代码10. Vue知识点解析10.1 数据绑…...

java调用dll出现unsatisfiedLinkError以及JNA和JNI的区别

UnsatisfiedLinkError 在对接硬件设备中&#xff0c;我们会遇到使用 java 调用 dll文件 的情况&#xff0c;此时大概率出现UnsatisfiedLinkError链接错误&#xff0c;原因可能有如下几种 类名错误包名错误方法名参数错误使用 JNI 协议调用&#xff0c;结果 dll 未实现 JNI 协…...

定时器任务——若依源码分析

分析util包下面的工具类schedule utils&#xff1a; ScheduleUtils 是若依中用于与 Quartz 框架交互的工具类&#xff0c;封装了定时任务的 创建、更新、暂停、删除等核心逻辑。 createScheduleJob createScheduleJob 用于将任务注册到 Quartz&#xff0c;先构建任务的 JobD…...

高危文件识别的常用算法:原理、应用与企业场景

高危文件识别的常用算法&#xff1a;原理、应用与企业场景 高危文件识别旨在检测可能导致安全威胁的文件&#xff0c;如包含恶意代码、敏感数据或欺诈内容的文档&#xff0c;在企业协同办公环境中&#xff08;如Teams、Google Workspace&#xff09;尤为重要。结合大模型技术&…...

Rust 异步编程

Rust 异步编程 引言 Rust 是一种系统编程语言,以其高性能、安全性以及零成本抽象而著称。在多核处理器成为主流的今天,异步编程成为了一种提高应用性能、优化资源利用的有效手段。本文将深入探讨 Rust 异步编程的核心概念、常用库以及最佳实践。 异步编程基础 什么是异步…...

企业如何增强终端安全?

在数字化转型加速的今天&#xff0c;企业的业务运行越来越依赖于终端设备。从员工的笔记本电脑、智能手机&#xff0c;到工厂里的物联网设备、智能传感器&#xff0c;这些终端构成了企业与外部世界连接的 “神经末梢”。然而&#xff0c;随着远程办公的常态化和设备接入的爆炸式…...

九天毕昇深度学习平台 | 如何安装库?

pip install 库名 -i https://pypi.tuna.tsinghua.edu.cn/simple --user 举个例子&#xff1a; 报错 ModuleNotFoundError: No module named torch 那么我需要安装 torch pip install torch -i https://pypi.tuna.tsinghua.edu.cn/simple --user pip install 库名&#x…...

视频行为标注工具BehaviLabel(源码+使用介绍+Windows.Exe版本)

前言&#xff1a; 最近在做行为检测相关的模型&#xff0c;用的是时空图卷积网络&#xff08;STGCN&#xff09;&#xff0c;但原有kinetic-400数据集数据质量较低&#xff0c;需要进行细粒度的标注&#xff0c;同时粗略搜了下已有开源工具基本都集中于图像分割这块&#xff0c…...

Aspose.PDF 限制绕过方案:Java 字节码技术实战分享(仅供学习)

Aspose.PDF 限制绕过方案&#xff1a;Java 字节码技术实战分享&#xff08;仅供学习&#xff09; 一、Aspose.PDF 简介二、说明&#xff08;⚠️仅供学习与研究使用&#xff09;三、技术流程总览四、准备工作1. 下载 Jar 包2. Maven 项目依赖配置 五、字节码修改实现代码&#…...

A2A JS SDK 完整教程:快速入门指南

目录 什么是 A2A JS SDK?A2A JS 安装与设置A2A JS 核心概念创建你的第一个 A2A JS 代理A2A JS 服务端开发A2A JS 客户端使用A2A JS 高级特性A2A JS 最佳实践A2A JS 故障排除 什么是 A2A JS SDK? A2A JS SDK 是一个专为 JavaScript/TypeScript 开发者设计的强大库&#xff…...