旋转矩阵的原理旋转矩阵是怎么个旋转法?是如何进行排列组合的?为什么就能做到覆盖了复式呢?明明有一些组合没有呀?

来源:学生作业帮助网 编辑:作业帮 时间:2024/06/04 15:07:46
旋转矩阵的原理旋转矩阵是怎么个旋转法?是如何进行排列组合的?为什么就能做到覆盖了复式呢?明明有一些组合没有呀?
xUKsG+QET;UddJ+U+dD %$r`ED^'r/YX9R2=|uOL|~^y!5Tv2 8V8K~Ѿڵw S7P`yjU+{ȴ4$ u zy>0xR)Z`[fJ3?HiZYHm] " }L=`mϪo408kzvar̋:?Vo0vk{y~ȯIN ]odsqQKCzYVQ !d KgD)(hCÏEd1B&#r?Ԣ6A .G"ЊߢcՌjKrS`t=X.^RaC PwBZ pSöc^D v$]Q TX`;]S&*麹lpVļp?$CFMT(R pl2;!)#38ԓO:3=Ư Պ}I:5,Lo7,*E&O8N`lnCX[ dXRB"n(]CޔR ]Pvې7!w2(ؼ2̷.X:]%|1Y~(_`p:LGPRY^ZJ Jd5h,++ 3U |1+\X!5x!r ថ9)&!㨧/[DM=` \#0: H}g

旋转矩阵的原理旋转矩阵是怎么个旋转法?是如何进行排列组合的?为什么就能做到覆盖了复式呢?明明有一些组合没有呀?
旋转矩阵的原理
旋转矩阵是怎么个旋转法?是如何进行排列组合的?为什么就能做到覆盖了复式呢?明明有一些组合没有呀?

旋转矩阵的原理旋转矩阵是怎么个旋转法?是如何进行排列组合的?为什么就能做到覆盖了复式呢?明明有一些组合没有呀?
①三元组表表示的矩阵转置的思想方法
  第一步:根据A矩阵的行数、列数和非零元总数确定B矩阵的列数、行数和非零元总数.
  第二步:当三元组表非空(A矩阵的非零元不为0)时,根据A矩阵三元组表的结点空间data(以下简称为三元组表),将A的三元组表a->data置换为B的三元组表b->data.
②三元组表的转置
 方法一:简单地交换a->data中i和j中的内容,得到按列优先顺序存储倒b->data;再将b->data重排成按行优先顺序的三元组表.
 方法二:由于A的列是B的行,因此,按a->data的列序转置,所得到的转置矩阵B的三元组表b->data必定是按行优先存放的.
 按这种方法设计的算法,其基本思想是:对A中的每一列col(0≤col≤a->n-1),通过从头至尾扫描三元组表a->data,找出所有列号等于col的那些三元组,将它们的行号和列号互换后依次放人b->data中,即可得到B的按行优先的压缩存贮表示.
③具体算法:
void TransMatrix(TriTupleTable *b,TriTupleTable *a)
{//*a,*b是矩阵A、B的三元组表表示,求A转置为B
int p,q,col;
b->m=a->n; b->n=a->m; //A和B的行列总数互换
b->t=a->t; //非零元总数
if(b->tdata[p].j==col){ //找列号为col的三元组
b->data[q).i=a->data[p].j;
b->data[q].j=a->data[p].i;
b->data[q].v=a->data[p].v;
q++;
}
} //TransMatrix
④算法分析
  该算法的时间主要耗费在col和p的二重循环上:
 若A的列数为n,非零元素个数t,则执行时间为O(n×t),即与A的列数和非零元素个数的乘积成正比.