24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 289  |  回复: 0

dengmin155

新虫 (初入文坛)

[求助] 这个程序怎么改啊 指针

这个程序是用来进行矩阵对角化的,但是,编译好后,一旦输入有零的矩阵元后,就会发生指令使得内存不可读的错误,如果矩阵中没有零元素,就很好用,这是采用雅可比方法编写的~求大侠相助!!

#include
#include
#include
#include
class jacobi
{private:
        int flag,i,iteration,j,k,n,b,h;
        double csa,eps1,eps2,eps3,p,q,s1,s2,sna,spq,sum,temp;
        double  *eigen,**a,**t;
public:
        jacobi()
        {
                iteration=0;flag=1;
                eps1=1e-10;eps2=1e-10;eps3=1e-10;
       
        }
void solution ();
~jacobi()
        {
         delete [] eigen;
         for (i=0;i; }
     delete [] a;
         for (i=0;i; }
        delete [] t;
        }
};

void main()
{        jacobi eigenpair;
        eigenpair.solution();

}


void jacobi::solution()
{ cout<<"输入矩阵阶数:";
cin>>n;
eigen=new double [n];
for (i=0;i=0.0; }
a=new double*[n];
for(i=0;i=new double [n];}
t=new double*[n];
for (i=0;i=new double [n];}
for (i=0;i for (j=0;j {t[j]=0.0;a[j]=0.0; }
for (i=0;i for (j=i;j {       
        cout<<"\n输入a["<         cin>>a[j];
    a[j]=a[j];
}
cout<<"输入矩阵结束"< s1=0.0;sum=0.0;
for (i=0;i         {       
                t=1.0;
                s1+=a*a;
                sum+=a;

        }
do
{
        iteration++;
        for(i=0;i                 for(j=(i+1);j                 {
                        if(fabs(a[j])[j]=0.0; a[j]=0;}
                        else
                        {
                                q=fabs(a-a[j][j]);
                                if (q>eps2)
                                {   b=i;h=j;
                                        p=2*a[j]*q/(a-a[j][j]);
                                        spq=sqrt(p*p+q*q);
                                        csa=sqrt((1+q/spq)/2);
                                        sna=p/(2*csa*spq);
                                }
                        else
                        {       
                                csa=0.707107;sna=csa;
                        }
                        for(k=0;k                         {        temp=t[k];
                                t[k]=temp*csa+t[k][j]*sna;
                                t[k][j]=temp*sna-t[k][j]*csa;
                       
                        }


             temp=a;
                         a=temp*csa*csa+a[h][h]*sna*sna+2*a[h]*csa*sna;
             a[h][h]=temp*sna*sna+a[h][h]*csa*csa-2*a[h]*csa*sna;
             a[h]=0;a[h]=0;
                         for(k=0;k                                  if((k!=b)&&(k!=h))
                                 {
                                         temp=a[k];
                                     a[k]=temp*csa+a[h][k]*sna;
                                     a[h][k]=temp*sna-1*a[h][k]*csa;//这里有点问题

                                 }

                        for        (k=0;k                                 if((k!=b)&&(k!=h))
                                {       
                                        temp=a[k];
                                        a[k]=temp*csa+a[k][h]*sna;//有问题,这里要注意a[h]的索引标的问题
                                        a[k][h]=temp*sna-1*a[k][h]*csa;
                                }


                         
                        }
                       
                }
        s2=0.0;
        for (i=0;i         {
                eigen=a;
                s2+=eigen*eigen;
        }
        if (fabs(1-s1/s2)         else { s1=s2;}

        }while(flag==1);

for (i=0;i {
        cout<<"\n特征值["<< }
cout<<"\n收敛于"< cout<<"\n输入矩阵的迹="< sum=0.0;
for(i=0;i; }
cout<<"\n特征值之和="< cout<<"\n特征向量是:"< cout.precision (4);
for(j=0;j         {
      cout<<"\n特征向量["<           for (i=0;i[j]<          
          cout<         }
system("pause";
}
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

智能机器人

Robot (super robot)

我们都爱小木虫

相关版块跳转 我要订阅楼主 dengmin155 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 一志愿南开大学0710生物学359求调剂 +6 兔兔兔111223314 2026-03-29 8/400 2026-04-02 22:37 by louise0220
[基金申请] 请问共同通讯和共同一作的认可度问题 10+4 psa1234 2026-04-01 9/450 2026-04-02 22:03 by god_tian
[考研] 一志愿武汉理工0856,初试334 +3 26考研材料 2026-04-02 3/150 2026-04-02 21:22 by dongzh2009
[考研] 321求调剂 一志愿 浙江工业大学生物医药 +5 嘿嘿HC 2026-04-01 6/300 2026-04-02 15:23 by sophie2180
[考研] 261求B区调剂 +5 明仔· 2026-04-01 7/350 2026-04-02 11:17 by 邹尉尉
[考研] 337求调剂 +11 《树》 2026-03-29 11/550 2026-04-02 10:20 by 不吃魚的貓
[考研] 08工科275分求调剂 +13 AaAa7420 2026-03-31 13/650 2026-04-02 06:19 by 286640313
[考研] 085602化学工程268分蹲调剂 +8 月照花林。 2026-04-01 8/400 2026-04-01 22:08 by 无际的草原
[考研] 273求调剂 +19 李芷新1 2026-03-31 19/950 2026-04-01 21:49 by chyhaha
[考研] 307分求调剂 +14 (o~o) 2026-03-31 15/750 2026-04-01 20:43 by longlotian
[考研] 材料与化工(0856)304求B区调剂 +8 邱gl 2026-03-30 16/800 2026-04-01 17:58 by 邱gl
[考研] 350求调剂 +7 阿佳~ 2026-03-31 7/350 2026-04-01 16:12 by yanflower7133
[考研] 0856,材料与化工321分求调剂 +13 大馋小子 2026-03-27 14/700 2026-04-01 15:58 by yanflower7133
[考研] 材料专硕322分 +9 哈哈哈吼吼吼哈 2026-04-01 9/450 2026-04-01 14:30 by 无际的草原
[考研] 289求调剂 +7 BrightLL 2026-03-29 7/350 2026-03-31 22:05 by 544594351
[考研] 313求调剂 +6 卖个关子吧 2026-03-31 6/300 2026-03-31 10:58 by Jaylen.
[考研] 274求调剂 +6 xiao爱同学 2026-03-30 6/300 2026-03-31 10:04 by cal0306
[考研] 22408 359分调剂 +4 Qshers 2026-03-27 8/400 2026-03-31 08:53 by Qshers
[考研] 343求调剂 +6 爱羁绊 2026-03-29 6/300 2026-03-29 12:00 by 无际的草原
[考研] 一志愿上海理工能源动力(085800)310分求调剂 +3 zhangmingc 2026-03-27 4/200 2026-03-27 19:01 by 给你你注意休息
信息提示
请填处理意见