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

旋转的数组

分享今天看到的一个题目,不同思路解法

题目 

                      

 思路1:时间复杂度0(N*k)

void rotate(int *a,int N,int k)//N为数组元素个数

{

       while(k--)

       {         

                int tem=a[N-1];

                for(int right=N-2;right>=0;right--)

                {

                a[right+1]=a[right];

                }

                a[0]=tem;

        }

 思路2(开辟一块空间):时间复杂度0(N)        空间复杂度o(N)

void rotate(int *a,int N,int k,int *b)//数组b        int b[sz]={0};

{

        for (int i = 0; i < k; i++)
            b[i] = a[sz-(k-i)];
        for(int i=k;i<sz;i++)
            b[i]= a[i-k];

}

 思路三单独逆置后整体逆置:

void Rt(int *a,int left,int right)//对区间[left:right]内的元素进行内置

{

        while(left<=right)

        {

                int tem=a[left];

                a[left]=a[right];

                a[right]=tem;

                ++left;

                --right;

        }

}

void rotate(int *a,int N;int k)

{

        Rt(a,N-k,N-1);//先逆序数组a的后k个       1 2 3 4 7 6 5

        Rt(a,0,N-k-1);//再逆序数组a前N-k个        4 3 2 1 7 6 5

        Rt(a,0,N);//最后逆序整个数组a                5 6 7 1 2 3 4

左后对上面代码进行分析,上述是以N=7,k=3的情况(k<N)。那么如果k>N怎么办N-k不是变成负数了吗?上述代码就显然不成立了。

但是我们可以发现当k=N时数组没有变化,所以可以看成逆序每N次一个循环,所以只要在主函数对函数rotate函数进行传参是传入k%Nj就能使上述代码依然成立了。 

http://www.lryc.cn/news/241928.html

相关文章:

  • Hive VS Spark
  • SAST静态分析工具所支持的规则
  • torch 的数据加载 Datasets DataLoaders
  • 【Promise】某个异步方法执行结束后 在执行下面方法
  • 任意文件下载漏洞(CVE-2021-44983)
  • C++(20):通过source_location实现日志函数
  • 【数据结构】树与二叉树(廿二):树和森林的遍历——后根遍历(递归算法PostOrder、非递归算法NPO)
  • 精通Nginx(17)-安全管控之防暴露、限制访问、防DDos攻击、防爬虫、防非法引用
  • STM32 Flash
  • 文件批量重命名技巧:图片文件名太长怎么办?告别手动改名方法
  • 微信小程序手写滑动tab
  • 一文读懂如何安全地存储密码
  • 【运维面试100问】(六)buffer和cache的区别
  • 创建域名邮箱邮件地址的方法与步骤
  • Qt框架学习(1)
  • 3D电路板在线渲染案例
  • ResizeObserver loop limit exceeded报错解决方案
  • 【OpenCV实现图像:使用OpenCV进行图像处理之透视变换】
  • Vue中学习笔记-数据代理
  • IDEA 配置maven结合案例使用篇
  • 基于白鲸算法优化概率神经网络PNN的分类预测 - 附代码
  • Android使用Kotlin利用Gson解析多层嵌套Json数据
  • DOM事件的传播机制
  • gitlab利用CI多工程持续构建
  • 【C++初阶】四、类和对象(构造函数、析构函数、拷贝构造函数、赋值运算符重载函数)
  • js粒子效果(二)
  • 01.让自己习惯C++
  • ElementUI table+dialog实现一个简单的可编辑的表格
  • Rust语言精讲:数据类型全解析
  • 《数据结构、算法与应用C++语言描述》-代码实现散列表(线性探查与链式散列)