本文介绍: 但是我们可以发现k=N时数组没有变化,所以可以看成逆序每N次一个循环,所以只要在主函数函数rotate函数进行传参是传入k%Nj就能使上述代码依然成立了。左后对上面代码进行分析,上述是以N=7,k=3的情况(k

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

题目 

                      

 思路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就能使上述代码依然成立了。 

原文地址:https://blog.csdn.net/2301_78670085/article/details/134588327

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。

如若转载,请注明出处:http://www.7code.cn/show_8605.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注