ملف:Backtang2.png

من أرابيكا، الموسوعة الحرة
اذهب إلى التنقل اذهب إلى البحث

الملف الأصلي(1٬024 × 1٬024 بكسل حجم الملف: 143 كيلوبايت، نوع MIME: image/png)

ملخص

الوصف
Italiano: Bak–Tang–Wiesenfeld sandpile, 28 million grains
التاريخ
المصدر عمل شخصي
المؤلف Claudio Rocchini

ترخيص

أنا، صاحب حقوق التأليف والنشر لهذا العمل، أنشر هذا العمل تحت الرخصة التالية:
w:ar:مشاع إبداعي
نسب العمل إلى مُؤَلِّفه
يحقُّ لك:
  • مشاركة العمل – نسخ العمل وتوزيعه وبثُّه
  • إعادة إنتاج العمل – تعديل العمل
حسب الشروط التالية:
  • نسب العمل إلى مُؤَلِّفه – يلزم نسب العمل إلى مُؤَلِّفه بشكل مناسب وتوفير رابط للرخصة وتحديد ما إذا أجريت تغييرات. بالإمكان القيام بذلك بأية طريقة معقولة، ولكن ليس بأية طريقة تشير إلى أن المرخِّص يوافقك على الاستعمال.

Source Code

#include <stdio.h>
#include <stdlib.h>
#include <queue>

typedef unsigned char byte;
typedef std::pair<int,int> coord;
const int    N = 1024;
const size_t C = 4;
const size_t S = 28000000;

byte M[N][N];
const int dx[4] = {1,0,-1,0}; 
const int dy[4] = {0,1,0,-1};

int main() {
    memset(M,0,N*N);
	
    for(size_t steps=0;steps<S;++steps) {
        std::queue<coord> q;
        if( ++M[N/2][N/2]>=C ) q.push( coord(N/2,N/2) );
        while( !q.empty() ) {
            const int x = q.front().first;
            const int y = q.front().second;
            q.pop();
            if(M[x][y]<C) continue;
            M[x][y] -= 4;
            for(int d=0;d<4;++d) {
                const int lx = x+dx[d];
                const int ly = y+dy[d];
                if(lx<0 || lx>=N) continue;
                if(ly<0 || ly>=N) continue;
		if(++M[lx][ly]>=C) q.push( coord(lx,ly) );
            }
        }
    }

    const byte co[4][3] = { {255,255,255}, {255,0,0}, {0,255,0}, {0,0,255} };
    FILE * fo = fopen("backtang2.ppm","wb");
    fprintf(fo,"P6\n%d %d\n255\n",N,N);
    for(int x=0;x<N;++x) for(int y=0;y<N;++y)
        fwrite(co[M[x][y]],1,3,fo);
    fclose(fo);

    return 0;
}

الشروحات

أضف شرحاً من سطر واحد لما يُمثِّله هذا الملف

العناصر المصورة في هذا الملف

يُصوِّر

٧ أغسطس 2012

f5e634e4c4716f43272e8c88965e575c784c5278

طريقة الاستدلال: SHA-1 الإنجليزية

١٤٥٬٩٤٨ بايت

١٬٠٢٤ بكسل

١٬٠٢٤ بكسل

تاريخ الملف

اضغط على زمن/تاريخ لرؤية الملف كما بدا في هذا الزمن.

زمن/تاريخصورة مصغرةالأبعادمستخدمتعليق
حالي13:27، 7 أغسطس 2012تصغير للنسخة بتاريخ 13:27، 7 أغسطس 20121٬024 × 1٬024 (143 كيلوبايت)commonswiki>Rocchini

ال1 ملف التالي مكررات لهذا الملف (المزيد من التفاصيل):

الصفحة التالية تستخدم هذا الملف: