OPTADS360
AANETWORK
AMBIENT
YOMEDIA
Banner-Video
IN_IMAGE

Viết một hàm nhập các phần tử của ma trận vuông cấp n, một hàm in ma trận theo cấu trúc hàng cột, một hàm tính định thức ma trận cấp n. Hàm main sử dụng các hàm này để nhập ma trận vuông cấp n, in ra ma trận, tính và in ra định thức của ma trận đó.

  bởi Cam Ngan 28/11/2021
ADSENSE/lession_isads=0
QUẢNG CÁO
 

Câu trả lời (1)

  • #include<conio.h>
    
    #include<iostream.h>
    
    float a[10][10];
    
    int n;
    
    void nhap();
    
    void xuat();
    
    void doicot(int,int);
    
    void truhang(int,int);
    
    float dinhthuc();
    
    void main()
    
    {clrscr();
    
    cout<<"Nhap kich thuoc ma tran vuong a: so hang = so cot <10, n="; cin>>n;
    
    cout<<"Nhap ma tran a :\n";
    
    nhap();
    
    cout<<"\nMa tran A :\n";
    
    xuat();
    
    cout<<"\n\nDinh thuc ma tran A :"<<dinhthuc();
    
    }
    
    void nhap()
    
    {int i,j,t;
    
    for (i=0;i<n;i++)
    
    {cout<<"Nhap cac phan tu hang thu "<<i+1<<":\n";
    
    for (j=0;j<n;j++)
    
    {cout<<"A["<<i+1<<","<<j+1<<"]="; cin>>t; a[i][j]=t;
    
    }
    
    }
    
    }
    
    void xuat()
    
    {int i,j;
    
    for (i=0;i<n;i++)
    
    {cout<<endl;
    
    for (j=0;j<n;j++)
    
    {cout<<" "; cout<<a[i][j];
    
    }
    
    }
    
    }
    
    void doicot(int k,int t)
    
    {int i;float p;
    
    for(i=0;i<n;i++)
    
    {p=a[i][k];
    
    a[i][k]=a[i][t];
    
    a[i][t]=p;
    
    }
    
    }
    
    void truhang(int h,int r)
    
    {int i;float x;
    
    x=-a[h][h]/a[r][h];
    
    for(i=h;i<n;i++) a[r][i]=a[h][i]+x*a[r][i];
    
    }
    
    float dinhthuc()
    
    { int i,j; float d=1;
    
      for (i=0;i<n-1;i++)
    
             { if(a[i][i]==0)
    
                  { for(j=i+1;(j<n)&&(a[i][j]==0);j++);
    
                     if(j<n)
    
                            { doicot(i,j); d=-d;
    
                             }
    
                     else d=0;
    
                   }
    
                if(d==0)break;
    
                for(j=i+1;j<n;j++)
    
                    if(a[j][i])truhang(i,j);
    
                }
    
     if(d) for(i=0;i<n;i++)d=d*a[i][i];
    
     return d;
    
    }
      bởi Hoai Hoai 28/11/2021
    Like (0) Báo cáo sai phạm

Nếu bạn hỏi, bạn chỉ thu về một câu trả lời.
Nhưng khi bạn suy nghĩ trả lời, bạn sẽ thu về gấp bội!

Lưu ý: Các trường hợp cố tình spam câu trả lời hoặc bị báo xấu trên 5 lần sẽ bị khóa tài khoản

Gửi câu trả lời Hủy
 
 

Các câu hỏi mới

NONE
OFF