Şimdi Ara

C++ matrisin Kofaktörü ve fonksiyon

Daha Fazla
Bu Konudaki Kullanıcılar: Daha Az
2 Misafir - 2 Masaüstü
5 sn
11
Cevap
1
Favori
1.373
Tıklama
Daha Fazla
İstatistik
  • Konu İstatistikleri Yükleniyor
0 oy
Öne Çıkar
Sayfa: 1
Giriş
Mesaj
  • Arkadaşlar bilgisayar müh. bölümünde değilim giriş seviyesinde programlama öğreniyoruz. ve bir ödevim var %70ini tamamladım ama bir kısmı kaldı bu kısımda yardımınızı istiyorum.
    matrislerle ilgili 3 isteğim olacak.

    Matrislerde kofaktör(işaretli minör) hesabı, ek matris ve bir de fonksiyon olarak yapılacak bir kısım var orayı da açıklayayım.girilen bir matrisin en büyük elemanını bularak kullanıcıya verecek. burada en büyük değeri hesaplama işlemi fonksiyon kullanılarak yapılması isteniyor.

    yardımcı olursanız çok sevinirim. iyi günler.



  • yardım lütfen fonksiyon olanı hallettim. ama diğer ikisi hala sorun.
  • biologyst B kullanıcısına yanıt
     
    void MatrixInversion(float **A, int order, float **Y)
    {
    // get the determinant of a
    double det = 1.0/CalcDeterminant(A,order);

    // memory allocation
    float *temp = new float[(order-1)*(order-1)];
    float **minor = new float*[order-1];
    for(int i=0;i<order-1;i++)
    minor[i] = temp+(i*(order-1));

    for(int j=0;j<order;j++)
    {
    for(int i=0;i<order;i++)
    {
    // get the co-factor (matrix) of A(j,i)
    GetMinor(A,minor,j,i,order);
    Y[i][j] = det*CalcDeterminant(minor,order-1);
    if( (i+j)%2 == 1)
    Y[i][j] = -Y[i][j];
    }
    }

    // release memory
    //delete [] minor[0];
    delete [] temp;
    delete [] minor;
    }

    // calculate the cofactor of element (row,col)
    int GetMinor(float **src, float **dest, int row, int col, int order)
    {
    // indicate which col and row is being copied to dest
    int colCount=0,rowCount=0;

    for(int i = 0; i < order; i++ )
    {
    if( i != row )
    {
    colCount = 0;
    for(int j = 0; j < order; j++ )
    {
    // when j is not the element
    if( j != col )
    {
    dest[rowCount][colCount] = src[i][j];
    colCount++;
    }
    }
    rowCount++;
    }
    }

    return 1;
    }

    // Calculate the determinant recursively.
    double CalcDeterminant( float **mat, int order)
    {
    // order must be >= 0
    // stop the recursion when matrix is a single element
    if( order == 1 )
    return mat[0][0];

    // the determinant value
    float det = 0;

    // allocate the cofactor matrix
    float **minor;
    minor = new float*[order-1];
    for(int i=0;i<order-1;i++)
    minor[i] = new float[order-1];

    for(int i = 0; i < order; i++ )
    {
    // get minor of element (0,i)
    GetMinor( mat, minor, 0, i , order);
    // the recusion is here!

    det += (i%2==1?-1.0:1.0) * mat[0][i] * CalcDeterminant(minor,order-1);
    //det += pow( -1.0, i ) * mat[0][i] * CalcDeterminant( minor,order-1 );
    }

    // release memory
    for(int i=0;i<order-1;i++)
    delete [] minor[i];
    delete [] minor;

    return det;
    }



    < Bu mesaj bu kişi tarafından değiştirildi hannibal1903 -- 19 Mayıs 2015; 17:22:17 >




  • hannibal1903 H kullanıcısına yanıt
    kütüphaneler neler eklenmeyecek mi ve bu şekilde derleyince calcDeterminant ve getMinor tanımlı değil diyor
  • biologyst B kullanıcısına yanıt
    #include <iostream>
    using namespace std;

    bunu ekledinmi başına fonksiyonun.
  • hannibal1903 H kullanıcısına yanıt
    denedim olmadı
  • biologyst B kullanıcısına yanıt
    Olmaswı lazım kardeş ne hatası alıyosun
  • Yapay Zeka’dan İlgili Konular
    Daha Fazla Göster
  • hannibal1903 H kullanıcısına yanıt
    derleyince calcDeterminant ve getMinor tanımlı değil diyor
  • main'in bunların üstünde kalmış olma ihtimali var mı?
  • welrocken W kullanıcısına yanıt
    burada sadece fonksiyonlar var bunun devamı da olması lazım sanırım
  • biologyst B kullanıcısına yanıt
    Kardeş bu fonksiyonları kullanarak istediğin işi yapabilirsin her türlü .Main olmasına gerek yok sen sadece mainde iki boyutlu bir matris oluşturup kullanacan başkada bir espirisi yok
  • 
Sayfa: 1
- x
Bildirim
mesajınız kopyalandı (ctrl+v) yapıştırmak istediğiniz yere yapıştırabilirsiniz.