数组旋转问题【有n个整数,使前面各数顺序向后移m个位置,最后m个数变成最前面m个数】

2023-05-16

目录

    • 一、问题描述:
    • 二、解题思路
    • 三、代码实现
    • 四、运行结果

一、问题描述:

有n个整数,使前面各数顺序向后移m个位置,最后m个数变成最前面m个数。比如原数组:
1 2 3 4 5 6 7(n=7,m=4)===>旋转后4 5 6 7 1 2 3

二、解题思路

  • 第一步:先将数组前n-m个数逆置
  • 第二部:再将数组剩下的m个数逆置
  • 第三步:最后将数组整体逆置
    在这里插入图片描述

三、代码实现

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>


//4 . 有n个整数 使前面的各数顺序后移m个位置  最后m个数变成前面m个数

//交换两个数
void swap(int* a, int* b) {
	int tmp = *a;
	*a = *b;
	*b = tmp;
}
//将数组low到high位置逆转
void reverse(int arr[], int low, int high) {
	while (low <= high) {
		swap(&arr[low], &arr[high]);
		low++;
		high--;
	}
}

//将arr数组 向后顺序移动m位 后m位变成前m位
void fun(int arr[], int length, int m) {
  //第一步
	reverse(arr, 0, length - m - 1);
	//第二步
	reverse(arr, length - m, length - 1);
	//第三步
	reverse(arr, 0, length - 1);
}
void print(int arr[], int n) {
	for (int i = 0; i < n; i++) {
		printf("%d ", arr[i]);
	}
}
int main()
{
	int arr[100];
	int n, m;//n个整数  m 需要顺序后移的偏移量
	printf("请输入n的个数:\n");
	scanf("%d", &n);
	printf("请输入每个数:\n");
	for (int i = 0; i < n; i++) {
		scanf("%d", &arr[i]);
	}
	printf("请输入顺序后移的量m:\n");
	scanf("%d", &m);
	printf("目前的序列:\n");
	print(arr, n);
	fun(arr, n, m);//将arr数组 向后顺序移动m位 后m位变成前m位
	printf("\n调整后的序列:\n");
	print(arr, n);
	return 0;
}

四、运行结果

在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

数组旋转问题【有n个整数,使前面各数顺序向后移m个位置,最后m个数变成最前面m个数】 的相关文章

  • P1591 阶乘数码洛谷

    题目描述 求n 中某个数码出现的次数 输入格式 第一行为t 10 xff0c 表示数据组数 接下来t行 xff0c 每行一个正整数n 1000 和数码a 输出格式 对于每组数据 xff0c 输出一个整数 xff0c 表示n 中a出现的次数
  • 多神经网络轨迹跟随控制(MATLAB实现)

    多神经网络轨迹跟随控制 xff08 MATLAB实现 xff09 本文是我基于自己的理解实现的多神经轨迹跟随控制 xff0c 可能不太正确 xff0c 但仍记录下来 此题目当我刚看到的时候一头雾水 xff0c 经过看PPT和自己实践貌似搞出
  • turtlebot3 Slam建图和导航仿真

    turtlebot3 Slam建图和导航仿真 使用RViz仿真Turtlebot3 RViz简介 RViz是ROS的三维可视化工具 它的主要目的是以三维方式显示ROS消息 xff0c 可以将数据进行可视化表达 例如无需编程即可表达激光测距仪
  • 【MATLAB APPdesigner ui设计实现软件动态页面启动 】(启动无标题栏)

    MATLAB APPdesigner实现软件动态页面启动 xff08 启动无标题栏 xff09 前言实现实现动态界面启动隐藏动态界面启动的标题栏 前言 最近需要验收利用MATLAB所实现的控制系统 xff0c 为了更好的展示 xff0c 因
  • 激光雷达方程推导与激光器参数指标

    激光雷达方程推导与激光器参数指标 激光雷达方程推导多种目标类型下的激光雷达方程激光器的参数指标 激光雷达方程推导 设定目标与激光雷达的距离为 R R R xff0c 发射激光束的发散角为
  • mpc模型预测控制原理详解

    mpc模型预测控制原理详解 前言mpc算法步骤mpc算法推导 前言 本文是对mpc模型预测控制学习的记录 xff0c 主要参照了DR CAN老师的视频进行学习 视频专栏链接 xff1a DR CAN老师mpc视频专栏 在这篇博客中博主也针对
  • C++基础回顾(上)

    C 43 43 基础回顾 xff08 上 xff09 目录 C 43 43 基础回顾 xff08 上 xff09 前言关键字和标识符运算符数据类型函数类 前言 C 43 43 之前学过一点 xff0c 但是很长时间都没用过 xff0c 翻出
  • 自适应控制专栏目录及介绍

    目录 自适应控制专栏目录及介绍第一篇 xff1a 具有不确定参数系统的自适应跟踪控制设计 ADi hhh的博客 CSDN博客 https blog csdn net qq 45830323 article details 129713051
  • 【五一创作】Qt quick基础1(包含基本元素Text Image Rectangle的使用)

    Qt quick基础1 xff08 包含基本元素Text Image Rectangle的使用 xff09 目录 Qt quick基础1 xff08 包含基本元素Text Image Rectangle的使用 xff09 前言qt中有直接设
  • 网站使用微信登录接口,所踩的坑...

    一 如何开通微信公众号 微信开发平台 授权认证 接口权限申请等等 xff0c 这些不在本文描述 xff0c 请参考官方资料 二 假设已顺利完成第一步的工作 xff0c 现在需要在自己开发的网站 xff08 PC端 移动端 xff0c 注意两
  • Qt quick基础2(包含平移旋转放缩以及qml控件大写开头啊)

    Qt quick基础2 xff08 包含平移旋转放缩以及qml控件大写开头啊 xff09 目录 Qt quick基础2 xff08 包含平移旋转放缩以及qml控件大写开头啊 xff09 前言简单的平移 旋转和放缩其他元素的一些基本使用qml
  • 虚幻引擎配置物体水面浮力的简便方法

    虚幻引擎配置物体水面浮力的简便方法 目录 虚幻引擎配置物体水面浮力的简便方法前言前期工作配置水面浮力针对一个立方体的水面浮力配置针对船3D模型的水面浮力配置 小结 前言 在使用虚幻引擎配置导入的3D模型时 xff0c 如何快速地将水面浮力配
  • 用栈实现回文字符串的判断

    用栈实现回文字符串的判断 栈是一种后进先出的数据结构 xff0c 它只能在一段进行插入和删除操作 例如一个字符串 34 12321 34 像这种 xff0c 无论正读反读均相同的字符序列 xff0c 就叫做回文字符串 首先 xff0c 我们
  • 安装diffuse 解决dpkg依赖问题

    安装diffuse报错 xff0c 缺少依赖 xff0c 安装地址 flynnsin 64 flynnsin Downloads span class token function sudo span dpkg span class tok
  • 软件工程整理

    软件工程总结 第一章1 软件2 软件工程3 软件工程环境4 三种编程范例 第二章1 软件生存周期2 软件生存周期的主要活动 3 软件过程 第三章1 结构化分析SA2 DFD xff08 数据流 xff09 图3 结构化设计SD xff08

随机推荐

  • TCP客户端增加多线程与TCP服务端增加多线程

    TCP客户端增加多线程 xff08 ps xff1a 仅有代码 xff0c 小伙伴们利用百度 xff0c 冲啊 xff01 xff01 xff01 xff09 span class token comment coding 61 utf 8
  • 梯度下降与矩阵分解

    1 梯度下降 梯度下降属于迭代法的一种 xff0c 所谓迭代法就是不断用变量的旧值得到新值的方法 在求解损失函数最小值的时候 xff0c 可以通过梯度下降法来一步步迭代求出最小化的损失函数和模型参数值 梯度 xff1a 对于一元函数来说 x
  • 求解gcd最大公约数的两种算法

    文章目录 1 更相减损术2 辗转相除法3 两种算法的比较 1 更相减损术 即 xff1a 辗转相减法 是由我国古代 九章算术 提出的一种求解最大公约数 Grand Central Dispatch 的算法 代码示例 xff1a span c
  • 【AWVS】python调AWVS接口 新建扫描并导出扫描报告(一)

    文章目录 前言一 先上完整python代码二 AWVS介绍三 准备工作1 获取 API KEY2 Header 设置1 接口介绍2 python代码 3 屏蔽警告 四 接口验证1 查看Targets扫描队列1 接口介绍2 python代码3
  • Echarts中国地图与世界地图实战

    文章目录 前言一 先上代码1 中国地图2 世界地图 二 图示1 中国地图2 世界地图 二 Echarts简介1 介绍2 实战流程1 引入echarts js2 定义一个图表容器DIV xff0c 定义id 61 xxx3 初始化echart
  • 部署微软的Bringing-Old-Photos-Back-to-Life,实战和踩坑

    在Windows 10上部署 微软的 Bringing Old Photos Back to Life 关于 Bringing Old Photos Back to Life部署的步骤1 下载源代码2 下载组件2 1 下载PyTorch h
  • 【AWVS】python调AWVS接口 新建扫描并导出扫描报告 [自定义扫描报告](三)

    文章目录 前言一 代码二 关键技术2 1 代码2 2 最重要的方法 replace 2 1 1 描述2 1 2 语法2 1 3 参数2 1 4 特别注意 2 3 实现方法2 3 1 修改左上角logo2 3 2 修改文字 三 修改图片的另一
  • 【web】data:image/png;python-base64用法与实现(一)

    文章目录 一 应用场景二 Data URI Scheme三 python base64文件编解码3 1 编码3 1 1 代码3 1 2 输出结果3 1 3 实现步骤 3 2 解码3 2 1 代码 一 应用场景 在html的源码中 xff0c
  • 【python】json.dumps() 与 json.loads() 用法

    文章目录 一 JSON介绍二 Python和Json数据类型的映射三 json load s 与json dump s 区别四 测试4 1 json dumps 4 2 json loads 4 3 json dump 4 4 json l
  • 【信息收集】利用Wappalyzer进行cms指纹识别(十)

    文章目录 一 Wappalyzer介绍二 设计原理三 python实现代码 一 Wappalyzer介绍 Wappalyzer 是一款浏览器插件 xff0c 通过 Wappalyzer 可以识别出网站采用了那种 web 技术 它能够检测出
  • 【word】批量添加图片题注与批量更新图注

    一 批量添加图注 1 选择一张图片插入题注 xff0c 选中题注 xff0c 然后快捷键shift 43 F9切换为域代码 2 CTRL 43 C复制 xff0c 然后CTRL 43 H打开查找和替换对话框 注意只选择 x y 部分 xff
  • 【Ubuntu】Ubuntu20基础配置+go开发配置

    这里写自定义目录标题 1 基础配置1 1 安装ifconfig网络管理工具1 2 初始化root密码1 3 换镜像源1 4 关闭息屏休眠1 5 关闭自动更新 2 开发环境2 1 go2 1 1 建立软件目录并安装软件2 1 2 建立go工作
  • 【git】git的一些基础操作

    文章目录 一 git下载二 git初次操作1 生成公钥2 修改全局用户名和邮箱地址 xff1a 3 本地仓库关联远端仓库4 本地初始化5 将项目上所有的文件添加到本地仓库6 提交到本地仓库7 创建main分支8 推送到main分支9 拉取远
  • 【anaconda】anaconda学习总结

    文章目录 1 anaconda介绍2 anaconda下载3 简单配置3 1 加入环境变量3 2 配置pycharm3 3 换源 4 相关命令 1 anaconda介绍 Anaconda指的是一个开源的Python发行版本 xff0c 其包
  • python项目打包成依赖

    python项目打包成依赖 xff08 可以pip install 安装 xff09 python打包成pip包 用途 xff1a 可以将别人的代码打包成pip包 xff0c 用pip安装到自己的项目中 xff0c 也可以将自己的代码打包
  • Linux热键详解:Tab键,Ctrl+c、Ctrl+d

    1 Tab键接在一串命令的第一个字段后面 xff0c 则为命令补全 xff1b 若输入is后按两下Tab键则会把所有以is开头的命令都显示出来 xff0c 若时输入ifcon因为其对应的命令只有ifconfig xff0c 所以按一下Tab
  • UI自动化之driver.Tap坐标定位

    相信做UI自动化的小伙伴都知道 xff0c appium不是左右页面的元素都能定位的到的 xff0c 尤其是原生中嵌套了H5页面 xff0c 所有这个时候我们可以通过坐标定位的方式去解决 xff0c 理论上坐标定位可以解决所有的元素识别问题
  • 宣传片制作技巧

    0x00 宣传片中故事脚本主要内容 客户名称和产品名称 xff1b 宣传片的长度以及每个镜头的时间 xff1b 镜头画面及其文字说明 xff1b 镜头声音的文字描述 xff1b 镜头的拍摄方式与组接方式 xff1b 特殊要求及其他注意事项
  • 2021年山东省职业院校技能大赛中职组“网络搭建与应用”赛项

    2021年山东省职业院校技能大赛 中职组 网络搭建与应用 赛项 竞赛试题 2021年 12月 3日 竞赛说明 一 竞赛内容分布 网络搭建与应用 竞赛共分三个部分 xff0c 其中 xff1a 第一部分 xff1a 网络搭建及安全部署项目 x
  • 数组旋转问题【有n个整数,使前面各数顺序向后移m个位置,最后m个数变成最前面m个数】

    目录 一 问题描述 xff1a 二 解题思路三 代码实现四 运行结果 一 问题描述 xff1a 有n个整数 xff0c 使前面各数顺序向后移m个位置 xff0c 最后m个数变成最前面m个数 比如原数组 xff1a 1 2 3 4 5 6 7