巧妙地数组之类的数据平移

最新博客地址,欢迎访问^_^

巧妙的序列型数据平移

原理

例如{1, 2, 3, 4, 5, 6, 7,8}要向左平移2个单位

  • 先将前两个数据{1,2}反转为{2,1}
  • 之后将后面的数据{3,4,5,6,7,8}反转为{8,7,6,5,4,3}
  • 两个片段的相对位置没有改变得到了{2,1,8,7,6,5,4,3}
  • 最后将总数据进行反转便得到了{3,4,5,6,7,8,1,2}

代码实现

C++实现

#include<iostream>

using namespace std;

void Myreverse(int(&a)[20], int Begin, int End);

int main()
{
   int N,Move,a[20];
   cin>>N>>Move;
   //对Move进行处理
   Move = Move % N;
   for(int i = 0;i < N;i ++)
   {
       cin>>a[i];
   }
   
   //传进反转的开始和结束的下标
   Myreverse(a , 0, Move - 1);
   Myreverse(a , Move, N - 1);
   Myreverse(a , 0, N - 1);
   for(int i = 0;i < N;i ++)
   {
       cout<<a[i]<<' ';
   }
   return 0;
}

void Myreverse(int(&a)[20], int Begin, int End)
{
   for(int i = Begin;i <= int((Begin + End) / 2);i ++)
   {
       int m = a[i];
       a[i] = a[End - (i - Begin)];
       a[End - (i - Begin)] = m;
   }
}

python实现(复制后注意修改注释符号为‘#’哦)

// 定义反转函数
def Myreverse(Begin, End):
   global a
   for i in  range(Begin, (Begin + End)//2 + 1):
       m = a[i]
       a[i] = a[End - (i - Begin)]
       a[End - (i - Begin)] = m
//输入数据        
term = [int(i) for i in input("请输入长度和左移量:").split()]
a = [int(i) for i in input("请输入数字序列:\n").split()]
length = term[0]
Move = term[1] % length
//进行反转
Myreverse(0, Move - 1)
Myreverse(Move, length - 1)
Myreverse(0, length - 1)

print("数组向左平移 %d 单位后的结果为:\n%s" % (Move, str(a)))

欢迎交流指正
Alt

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Matlab是一个强大的数学计算工具,其数组的使用方式也非常巧妙。下面介绍一些Matlab数组巧妙用法: 1. 向量化运算 Matlab的向量化运算功能使得我们可以对整个数组进行操作而不用循环遍历每个元素。比如,如果我们想将一个数组中的所有元素都乘以2,可以使用以下代码: ``` A = [1 2 3; 4 5 6; 7 8 9]; A = A * 2; ``` 这里的`A`是一个3x3的矩阵,`A * 2`会将矩阵中的每个元素都乘以2。 2. 多维数组的索引 Matlab支持多维数组的索引,这样我们可以更方便地访问数组中的元素。比如,如果我们想访问一个3维数组中的某个元素,可以使用以下代码: ``` A = rand(3,4,5); val = A(2,3,4); ``` 这里的`A`是一个3x4x5的数组,`A(2,3,4)`表示访问第2个维度、第3个维度和第4个维度上的元素。 3. 利用数组进行拟合 Matlab提供了许多拟合函数(如polyfit)来拟合数据,但有时候我们可以利用数组的性质来进行拟合。比如,如果我们想用一个二次曲线来拟合一组数据,可以使用以下代码: ``` x = linspace(-1,1,100); y = 2*x.^2 + 3*x + 1 + randn(1,100)*0.1; % 添加一些噪声 A = [x.^2; x; ones(1,length(x))]'; b = y'; coef = A\b; ``` 这里的`x`和`y`是一组数据,我们想用一个二次曲线来拟合它们。我们可以将二次曲线表示为`y = ax^2 + bx + c`,然后将x的二次方、x和1作为矩阵A的三列,将y作为矩阵b的一列,然后用线性代数中的最小二乘法求解系数a、b、c。 4. 利用数组进行卷积 Matlab提供了许多处理信号和图像的函数,其中一个非常有用的函数是conv,它可以用来进行卷积操作。比如,如果我们想对一个信号进行平滑处理,可以使用以下代码: ``` x = randn(1,100); % 生成一组随机信号 h = ones(1,10)/10; % 生成一个长度为10的平均滤波器 y = conv(x,h,'same'); ``` 这里的`x`是一组随机信号,我们想对它进行平滑处理。我们可以生成一个长度为10的平均滤波器`h`,然后使用conv函数对信号进行卷积操作,得到平滑后的信号`y`。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值