bugün
- yerden kaç para bulursanız alırsınız12
- kamos9
- akşam mideniz kazınınca ne yiyorsunuz10
- allah ahiretimizi biliyorsa bizi neden yarattı15
- türkiye30
- bi hayvan olmak istesen ne olurdun37
- ataistlerin cevab veremediği sorular27
- düşün ki o bunu okuyor13
- 2025 iran israil çatışmaları13
- çıplak gösteren gözlük bugün mümkün11
- kaan'ın f35 den daha iyi olması18
- ibb'nin soyulup soğana çevirilmesi15
- akp'ye hala oy verenlerin motivasyonu24
- şuan yaşadığın fiziksel rahatsızlığı söyle9
- bütün yazarlar bir lira verse11
- teoman çalmaşur8
- baykar'ı protesto edenlerin gözaltına alınması11
- boş yuva sendromu8
- sevmediğim yazarları açıklıyorum8
- yazarların en sevdiği ilaç18
- sudekiray true'ya karşı11
- iran15
- havanın gavur amı gibi yanması13
- cevap vermez belirtir gider15
- chp8
- cumhuriyet halk partisi15
- dubaide 130 milyon dolara ev10
- en son ne yediniz15
- fotokopici bi erkek9
- araba61
- yazarların etnik kökeni10
- bilim adamı olsaydınız ne icat ederdiniz15
- sözlük erkeklerinin bugünkü kombinleri26
- pandela 38
- iranın hastane vurması8
- necip fazıla ait olmayan sözler8
- iyi ki doğdun manyak olmaya karar verdim9
- cep telefonu33
- israilli bakanın hastane vurmak savaş suçu demesi16
- damat bayraktar'ın israil tedarikçisiyle ortaklığı18
- en son ne zaman 31 çektiniz12
- ateizmle yönetilen bir ülkede olacaklar16
- herkesin dini kendine12
- çalışma hayatına dair prensipler15
- mokv10
- öfkeli korkusuz insan aptal insandır8
- kadınların gerçek yüzünü öğrenme yolları20
- öfkeli olanlara tavsiyeler9
- mantarlı vajina11
- tanrının çalışma prensibi12
basit bir c programıyla bile öğrenilebilir!
kratertepesi@msi:~/Masaüstü/Programlar$ ./program
100 milyon sayı içinde 10030385 asal sayı vardır.
işlemci döngüsü: 4772581176
Hesaplama süresi: 1.0846775400 saniye
1 saniyenin 10,000'de kaçı: 10846.7754000000
kod:
#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
#include <x86intrin.h> // RDTSC için gerekli
#define LIMIT 180000000 // 1 milyar sınırı
#define CPU_FREQUENCY 4.4 // GHz cinsinden işlemci frekansı (örneğin 3.0 GHz)
int main() {
unsigned long long i, j, count = 0;
bool *is_prime = malloc((LIMIT + 1) * sizeof(bool));
if (is_prime == NULL) {
fprintf(stderr, "Bellek tahsis edilemedi.\n");
return 1;
}
// Zaman ölçüm başlangıcı
unsigned long long start = __rdtsc();
// Bütün sayıları asal varsayıyoruz
for (i = 0; i <= LIMIT; i++) {
is_prime[i] = true;
}
// 0 ve 1 asal değildir
is_prime[0] = is_prime[1] = false;
// Eratosthenes Eleği algoritması
for (i = 2; i * i <= LIMIT; i++) {
if (is_prime[i]) {
for (j = i * i; j <= LIMIT; j += i) {
is_prime[j] = false;
}
}
}
// Asal sayıları sayıyoruz
for (i = 2; i <= LIMIT; i++) {
if (is_prime[i]) {
count++;
}
}
// Zaman ölçüm bitişi
unsigned long long end = __rdtsc();
// Döngü farkını hesapla
unsigned long long cycles = end - start;
// Döngü süresi saniye olarak
double time_seconds = cycles / (CPU_FREQUENCY * 1e9); // GHz'den Hz'e dönüşüm
// Sonuçları yazdır
printf("100 milyon sayı içinde %llu asal sayı vardır.\n", count);
printf("işlemci döngüsü: %llu\n", cycles);
printf("Hesaplama süresi: %.10f saniye\n", time_seconds);
printf("1 saniyenin 10,000'de kaçı: %.10f\n", time_seconds * 10000);
// Belleği serbest bırak
free(is_prime);
return 0;
}
kratertepesi@msi:~/Masaüstü/Programlar$ ./program
100 milyon sayı içinde 10030385 asal sayı vardır.
işlemci döngüsü: 4772581176
Hesaplama süresi: 1.0846775400 saniye
1 saniyenin 10,000'de kaçı: 10846.7754000000
kod:
#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
#include <x86intrin.h> // RDTSC için gerekli
#define LIMIT 180000000 // 1 milyar sınırı
#define CPU_FREQUENCY 4.4 // GHz cinsinden işlemci frekansı (örneğin 3.0 GHz)
int main() {
unsigned long long i, j, count = 0;
bool *is_prime = malloc((LIMIT + 1) * sizeof(bool));
if (is_prime == NULL) {
fprintf(stderr, "Bellek tahsis edilemedi.\n");
return 1;
}
// Zaman ölçüm başlangıcı
unsigned long long start = __rdtsc();
// Bütün sayıları asal varsayıyoruz
for (i = 0; i <= LIMIT; i++) {
is_prime[i] = true;
}
// 0 ve 1 asal değildir
is_prime[0] = is_prime[1] = false;
// Eratosthenes Eleği algoritması
for (i = 2; i * i <= LIMIT; i++) {
if (is_prime[i]) {
for (j = i * i; j <= LIMIT; j += i) {
is_prime[j] = false;
}
}
}
// Asal sayıları sayıyoruz
for (i = 2; i <= LIMIT; i++) {
if (is_prime[i]) {
count++;
}
}
// Zaman ölçüm bitişi
unsigned long long end = __rdtsc();
// Döngü farkını hesapla
unsigned long long cycles = end - start;
// Döngü süresi saniye olarak
double time_seconds = cycles / (CPU_FREQUENCY * 1e9); // GHz'den Hz'e dönüşüm
// Sonuçları yazdır
printf("100 milyon sayı içinde %llu asal sayı vardır.\n", count);
printf("işlemci döngüsü: %llu\n", cycles);
printf("Hesaplama süresi: %.10f saniye\n", time_seconds);
printf("1 saniyenin 10,000'de kaçı: %.10f\n", time_seconds * 10000);
// Belleği serbest bırak
free(is_prime);
return 0;
}
Gündemdeki Haberler
güncel Önemli Başlıklar