Computer Programming অ্যারে (Arrays in C) গাইড ও নোট

461

অ্যারে হল একই ধরনের ডেটার উপাদানের একটি সংকলন যা একটি নির্দিষ্ট পরিমাণে একযোগে সংরক্ষণ করা হয়। C প্রোগ্রামিং ভাষায় অ্যারে ব্যবহার করে আপনি বিভিন্ন ধরনের ডেটা একত্রে পরিচালনা করতে পারেন। নিচে C তে অ্যারের সংজ্ঞা, ডিক্লারেশন, ইনিশিয়ালাইজেশন, এবং বিভিন্ন কার্যকারিতা নিয়ে বিস্তারিত আলোচনা করা হলো।


১. অ্যারে কি?

অ্যারে হল একাধিক মান সংরক্ষণ করার জন্য একটি ডেটা স্ট্রাকচার। এটি একই ধরনের ডেটা টাইপের একটি সিরিজ, যা একযোগে একাধিক মান সংরক্ষণ করতে ব্যবহৃত হয়।

উদাহরণ:

যদি আপনার পাঁচটি পূর্ণ সংখ্যা সংরক্ষণ করতে হয়, তবে একটি অ্যারে ব্যবহার করতে পারেন।

২. অ্যারে ডিক্লারেশন

অ্যারে ডিক্লারেশনের সময় আপনাকে এর ডেটা টাইপ এবং সাইজ নির্ধারণ করতে হয়।

সিনট্যাক্স:

data_type array_name[array_size];

উদাহরণ:

int numbers[5]; // একটি পূর্ণসংখ্যার অ্যারে যা 5টি উপাদান ধারণ করে

৩. অ্যারে ইনিশিয়ালাইজেশন

অ্যারে ইনিশিয়ালাইজেশনের মাধ্যমে একাধিক মান একসাথে বরাদ্দ করা যায়।

উদাহরণ:

int numbers[5] = {1, 2, 3, 4, 5}; // অ্যারে তৈরি এবং ইনিশিয়ালাইজেশন

ডিফল্ট মান সহ ইনিশিয়ালাইজেশন:

int numbers[5] = {1, 2}; // বাকী উপাদানগুলি 0 দ্বারা ইনিশিয়ালাইজ হবে

৪. অ্যারে অ্যাক্সেস করা

অ্যারের উপাদানগুলিতে অ্যাক্সেস করতে ইনডেক্স ব্যবহার করা হয়। ইনডেক্সটি 0 থেকে শুরু হয়।

উদাহরণ:

#include <stdio.h>

int main() {
    int numbers[5] = {1, 2, 3, 4, 5};

    // অ্যারের উপাদানগুলি প্রিন্ট করা
    for (int i = 0; i < 5; i++) {
        printf("%d ", numbers[i]); // Output: 1 2 3 4 5
    }

    return 0;
}

৫. অ্যারে ফাংশনে পাস করা

C তে অ্যারে ফাংশনের মাধ্যমে পাস করা যায়, যা ডেটা প্রক্রিয়াকরণে সহায়ক।

উদাহরণ:

#include <stdio.h>

// ফাংশন ডিক্লারেশন
void printArray(int arr[], int size) {
    for (int i = 0; i < size; i++) {
        printf("%d ", arr[i]); // অ্যারের উপাদানগুলি প্রিন্ট করা
    }
}

int main() {
    int numbers[] = {1, 2, 3, 4, 5};
    printArray(numbers, 5); // অ্যারে ফাংশনে পাস করা
    return 0;
}

৬. মাল্টিডাইমেনশনাল অ্যারে

C তে মাল্টিডাইমেনশনাল অ্যারেও তৈরি করা যায়, যা টেবিল বা ম্যাট্রিক্সের মতো ডেটা সংরক্ষণ করতে সহায়ক।

উদাহরণ:

#include <stdio.h>

int main() {
    int matrix[2][3] = {
        {1, 2, 3},
        {4, 5, 6}
    };

    // মাল্টিডাইমেনশনাল অ্যারের উপাদানগুলি প্রিন্ট করা
    for (int i = 0; i < 2; i++) {
        for (int j = 0; j < 3; j++) {
            printf("%d ", matrix[i][j]);
        }
        printf("\n"); // নতুন লাইনে চলে যাওয়া
    }

    return 0;
}

৭. অ্যারে এবং পয়েন্টার

C তে অ্যারের নাম একটি পয়েন্টারের মতো কাজ করে, যা প্রথম উপাদানের ঠিকানা নির্দেশ করে।

উদাহরণ:

#include <stdio.h>

int main() {
    int numbers[] = {1, 2, 3, 4, 5};
    int *ptr = numbers; // অ্যারে নাম পয়েন্টারে বরাদ্দ

    // পয়েন্টার ব্যবহার করে অ্যারের উপাদানগুলি প্রিন্ট করা
    for (int i = 0; i < 5; i++) {
        printf("%d ", *(ptr + i)); // Output: 1 2 3 4 5
    }

    return 0;
}
Content added By

অ্যারের ধারণা এবং প্রয়োজনীয়তা

643

অ্যারে (Arrays) হল এক ধরনের ডেটা স্ট্রাকচার যা একই ধরনের ডেটার উপাদানগুলোকে একটি নির্দিষ্ট সাইজের সঙ্গোপনে (contiguous) সংরক্ষণ করে। C প্রোগ্রামিং ভাষায় অ্যারে ব্যবহার করে আপনি দ্রুত এবং কার্যকরীভাবে ডেটা পরিচালনা করতে পারেন। নিচে অ্যারের ধারণা এবং প্রয়োজনীয়তা বিস্তারিতভাবে আলোচনা করা হলো।


১. অ্যারের ধারণা

অ্যারে হল একটি ডেটা স্ট্রাকচার যা একই ধরনের ডেটার উপাদানগুলোকে একত্রে সংরক্ষণ করে। এটি একটি নামকৃত ভেরিয়েবল, যা একাধিক মান ধারণ করতে সক্ষম।

বৈশিষ্ট্য:

  • একই ডেটা টাইপ: একটি অ্যারে এক ধরনের ডেটা ধারণ করে, যেমন পূর্ণসংখ্যা, দশমিক সংখ্যা, অক্ষর ইত্যাদি।
  • ফিক্সড সাইজ: অ্যারের সাইজ নির্ধারিত হয় যখন এটি ডিক্লেয়ার করা হয় এবং এটি চলাকালীন পরিবর্তন করা যায় না।
  • সাধারণ অ্যাক্সেস: অ্যারের উপাদানগুলো ইনডেক্সের মাধ্যমে অ্যাক্সেস করা হয়, যেখানে ইনডেক্স 0 থেকে শুরু হয়।

অ্যারে ডিক্লারেশন:

data_type array_name[array_size];

উদাহরণ:

int numbers[5]; // একটি পূর্ণসংখ্যার অ্যারে যা 5টি উপাদান ধারণ করে

২. অ্যারের প্রয়োজনীয়তা

অ্যারে ব্যবহারের কিছু গুরুত্বপূর্ণ কারণ নিচে উল্লেখ করা হলো:

তথ্য সংগঠনের জন্য কার্যকরী পদ্ধতি:

  • অ্যারে ব্যবহার করে আপনি সম্পর্কযুক্ত ডেটা একত্রে সংগঠিত করতে পারেন, যা ডেটা প্রক্রিয়াকরণের জন্য সুবিধাজনক।

দ্রুত অ্যাক্সেস:

  • অ্যারের উপাদানগুলো ইনডেক্স ব্যবহার করে দ্রুত অ্যাক্সেস করা যায়, যা সনাক্তকরণের সময়কে কমায়।

স্ট্যাটিক ডেটা স্টোরেজ:

  • অ্যারে ডিক্লারেশন সময় সাইজ নির্ধারণ করা হয়, যা মেমরি ব্যবহারে সঙ্গতি এবং স্বচ্ছতা নিশ্চিত করে।

পুনঃব্যবহারযোগ্য কোড:

  • অ্যারের মাধ্যমে আপনি কোডের পুনঃব্যবহার করতে পারেন এবং কাজের সময় কোডের গঠনকে সহজ করতে পারেন।

অ্যানালিটিক্স এবং গণনা:

  • অ্যারে ব্যবহার করে আপনি গণনা, মেট্রিক্স বিশ্লেষণ এবং অন্যান্য পরিসংখ্যানগত অপারেশন করতে পারেন।

ডেটা ম্যানিপুলেশন:

  • অ্যারে বিভিন্ন ধরনের ডেটা ম্যানিপুলেশন যেমন সার্চিং, সোর্টিং, এবং ম্যানিপুলেশন করতে সহায়ক।

কমপ্লেক্স ডেটা স্ট্রাকচার:

  • মাল্টিডাইমেনশনাল অ্যারে (যেমন ম্যাট্রিক্স) ব্যবহার করে জটিল ডেটা স্ট্রাকচার তৈরি করা সম্ভব।
Content added By

1D এবং 2D অ্যারের ব্যবহার

923

অ্যারে হল একই ধরনের ডেটার উপাদানের একটি সংগঠন। C প্রোগ্রামিং ভাষায়, অ্যারের প্রধান দুটি প্রকার হল 1D অ্যারে এবং 2D অ্যারে। নিচে 1D এবং 2D অ্যারের ব্যবহার এবং উদাহরণসহ আলোচনা করা হলো।


১. 1D অ্যারে (এক-মাত্রিক অ্যারে)

1D অ্যারে হল একটি একক র‍্যাঙ্কের অ্যারে যা একই ধরনের ডেটার একটি সেকেনশিয়াল সংগ্রহ। এটি সাধারণত একটি তালিকা হিসেবে কাজ করে।

১.১ ডিক্লারেশন এবং ইনিশিয়ালাইজেশন

int numbers[5]; // 1D অ্যারে ডিক্লারেশন
int numbers[] = {1, 2, 3, 4, 5}; // ইনিশিয়ালাইজেশন

১.২ অ্যারে অ্যাক্সেস

1D অ্যারের উপাদানগুলিতে ইনডেক্স ব্যবহার করে অ্যাক্সেস করা হয়, যেখানে ইনডেক্স 0 থেকে শুরু হয়।

উদাহরণ:

#include <stdio.h>

int main() {
    int numbers[] = {1, 2, 3, 4, 5};

    // 1D অ্যারের উপাদান প্রিন্ট করা
    for (int i = 0; i < 5; i++) {
        printf("%d ", numbers[i]); // Output: 1 2 3 4 5
    }

    return 0;
}

২. 2D অ্যারে (দুই-মাত্রিক অ্যারে)

2D অ্যারে হল একটি টেবিলের মতো ডেটা স্ট্রাকচার যেখানে সারি এবং কলাম উভয়ই থাকে। এটি সাধারণত ম্যাট্রিক্সের জন্য ব্যবহৃত হয়।

২.১ ডিক্লারেশন এবং ইনিশিয়ালাইজেশন

int matrix[2][3]; // 2D অ্যারে ডিক্লারেশন
int matrix[2][3] = {{1, 2, 3}, {4, 5, 6}}; // ইনিশিয়ালাইজেশন

২.২ অ্যারে অ্যাক্সেস

2D অ্যারের উপাদানগুলি ইনডেক্সের মাধ্যমে অ্যাক্সেস করা হয়, যেমন matrix[row][column]

উদাহরণ:

#include <stdio.h>

int main() {
    int matrix[2][3] = {
        {1, 2, 3},
        {4, 5, 6}
    };

    // 2D অ্যারের উপাদান প্রিন্ট করা
    for (int i = 0; i < 2; i++) {
        for (int j = 0; j < 3; j++) {
            printf("%d ", matrix[i][j]); // Output: 1 2 3 4 5 6
        }
        printf("\n"); // নতুন লাইনে চলে যাওয়া
    }

    return 0;
}

৩. 1D এবং 2D অ্যারের ব্যবহার

1D এবং 2D অ্যারে বিভিন্ন প্রয়োগে ব্যবহৃত হয়:

1D অ্যারের ব্যবহার:

  • তালিকা তৈরি করা: যেমন ব্যবহারকারীর ইনপুট সংরক্ষণ।
  • ফলাফলের স্টোরেজ: যেমন পরীক্ষায় স্কোর সংগ্রহ করা।

2D অ্যারের ব্যবহার:

  • টেবিল এবং ম্যাট্রিক্স: যেমন অঙ্কের ক্যালকুলেশন।
  • গ্রাফিক্স: পিক্সেল ডেটা সংরক্ষণ।
Content added By

অ্যারে ম্যানিপুলেশন (ইনসার্ট, ডিলিট, সার্চ)

374

অ্যারে ম্যানিপুলেশন হল একটি গুরুত্বপূর্ণ প্রক্রিয়া যা অ্যারের উপাদানগুলির মধ্যে ইনসার্ট, ডিলিট এবং সার্চ করার জন্য ব্যবহৃত হয়। নিচে C প্রোগ্রামিং ভাষায় এই তিনটি কার্যকলাপের বিস্তারিত আলোচনা করা হলো।


১. ইনসার্ট (Insert)

অ্যারে ইনসার্ট করার মাধ্যমে নতুন উপাদান অ্যারেতে যুক্ত করা হয়। একটি নির্দিষ্ট পজিশনে উপাদান যুক্ত করতে পারা যায়।

উদাহরণ:

#include <stdio.h>

void insert(int arr[], int *size, int element, int position) {
    // Shift elements to the right
    for (int i = *size; i > position; i--) {
        arr[i] = arr[i - 1];
    }
    arr[position] = element; // Insert the new element
    (*size)++; // Increase the size
}

int main() {
    int arr[10] = {1, 2, 3, 4, 5};
    int size = 5;

    int element = 10; // Element to insert
    int position = 2; // Position to insert

    insert(arr, &size, element, position);

    // Print updated array
    for (int i = 0; i < size; i++) {
        printf("%d ", arr[i]); // Output: 1 2 10 3 4 5
    }

    return 0;
}

২. ডিলিট (Delete)

অ্যারে থেকে একটি উপাদান মুছে ফেলা হলে, বাকি উপাদানগুলিকে স্থানান্তর করতে হয়।

উদাহরণ:

#include <stdio.h>

void delete(int arr[], int *size, int position) {
    // Shift elements to the left
    for (int i = position; i < *size - 1; i++) {
        arr[i] = arr[i + 1];
    }
    (*size)--; // Decrease the size
}

int main() {
    int arr[10] = {1, 2, 3, 4, 5};
    int size = 5;

    int position = 2; // Position to delete

    delete(arr, &size, position);

    // Print updated array
    for (int i = 0; i < size; i++) {
        printf("%d ", arr[i]); // Output: 1 2 4 5
    }

    return 0;
}

৩. সার্চ (Search)

অ্যারে থেকে একটি নির্দিষ্ট উপাদান খুঁজে বের করার জন্য সার্চিং ব্যবহার করা হয়। সাধারণত Linear Search এবং Binary Search ব্যবহৃত হয়।

৩.১ Linear Search

Linear Search প্রতিটি উপাদান পরীক্ষা করে উপাদান খুঁজে বের করে।

#include <stdio.h>

int linearSearch(int arr[], int size, int element) {
    for (int i = 0; i < size; i++) {
        if (arr[i] == element) {
            return i; // Return the index of the element
        }
    }
    return -1; // Element not found
}

int main() {
    int arr[] = {1, 2, 3, 4, 5};
    int size = 5;
    int element = 3;

    int index = linearSearch(arr, size, element);
    if (index != -1) {
        printf("Element %d found at index %d\n", element, index); // Output: Element 3 found at index 2
    } else {
        printf("Element not found.\n");
    }

    return 0;
}

৩.২ Binary Search

Binary Search শুধুমাত্র সাজানো অ্যারের জন্য কার্যকরী। এটি মধ্যবর্তী উপাদান পরীক্ষা করে উপাদানটি ছোট বা বড় কিনা তা নির্ধারণ করে।

#include <stdio.h>

int binarySearch(int arr[], int size, int element) {
    int left = 0, right = size - 1;

    while (left <= right) {
        int mid = left + (right - left) / 2;

        if (arr[mid] == element) {
            return mid; // Element found
        }
        if (arr[mid] < element) {
            left = mid + 1; // Search right half
        } else {
            right = mid - 1; // Search left half
        }
    }
    return -1; // Element not found
}

int main() {
    int arr[] = {1, 2, 3, 4, 5}; // Sorted array
    int size = 5;
    int element = 4;

    int index = binarySearch(arr, size, element);
    if (index != -1) {
        printf("Element %d found at index %d\n", element, index); // Output: Element 4 found at index 3
    } else {
        printf("Element not found.\n");
    }

    return 0;
}
Content added By

Multidimensional Arrays এবং Dynamic Arrays

266

মাল্টিডাইমেনশনাল অ্যারে এবং ডাইনামিক অ্যারে হল C প্রোগ্রামিং ভাষায় ডেটা সংগঠনের দুটি গুরুত্বপূর্ণ কৌশল। নিচে এগুলোর ধারণা, প্রয়োগ, এবং উদাহরণসহ বিস্তারিত আলোচনা করা হলো।


১. মাল্টিডাইমেনশনাল অ্যারে (Multidimensional Arrays)

মাল্টিডাইমেনশনাল অ্যারে হল একটি অ্যারে যা একাধিক মাত্রায় ডেটা সংরক্ষণ করতে সক্ষম। সবচেয়ে সাধারণ উদাহরণ হল 2D অ্যারে (দুই-মাত্রিক অ্যারে), যা সারি এবং কলাম হিসেবে সংগঠিত হয়।

১.১ ডিক্লারেশন এবং ইনিশিয়ালাইজেশন

int matrix[2][3]; // 2D অ্যারে ডিক্লারেশন
int matrix[2][3] = {
    {1, 2, 3},
    {4, 5, 6}
}; // ইনিশিয়ালাইজেশন

১.২ অ্যারে অ্যাক্সেস

2D অ্যারের উপাদানগুলি ইনডেক্স ব্যবহার করে অ্যাক্সেস করা হয়।

উদাহরণ:

#include <stdio.h>

int main() {
    int matrix[2][3] = {
        {1, 2, 3},
        {4, 5, 6}
    };

    // 2D অ্যারের উপাদানগুলি প্রিন্ট করা
    for (int i = 0; i < 2; i++) {
        for (int j = 0; j < 3; j++) {
            printf("%d ", matrix[i][j]); // Output: 1 2 3 4 5 6
        }
        printf("\n"); // নতুন লাইনে চলে যাওয়া
    }

    return 0;
}

২. ডাইনামিক অ্যারে (Dynamic Arrays)

ডাইনামিক অ্যারে হল এমন একটি অ্যারে যার সাইজ চলাকালীন সময়ে নির্ধারণ করা হয়। এটি মেমরি ব্যবস্থাপনার জন্য malloc() এবং free() ফাংশন ব্যবহার করে ডাইনামিকভাবে তৈরি করা হয়।

২.১ ডাইনামিক অ্যারে তৈরি করা

#include <stdio.h>
#include <stdlib.h> // malloc() এবং free() এর জন্য

int main() {
    int n; // অ্যারের সাইজ
    printf("Enter the size of the array: ");
    scanf("%d", &n);

    // ডাইনামিক অ্যারে তৈরি করা
    int *arr = (int *)malloc(n * sizeof(int));

    // অ্যারে ইনিশিয়ালাইজেশন
    for (int i = 0; i < n; i++) {
        arr[i] = i + 1; // 1 থেকে n পর্যন্ত মান
    }

    // অ্যারের উপাদানগুলি প্রিন্ট করা
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]); // Output: 1 2 3 ... n
    }
    printf("\n");

    // মেমরি মুক্ত করা
    free(arr);

    return 0;
}

২.২ ডাইনামিক 2D অ্যারে তৈরি করা

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

int main() {
    int rows, cols;
    printf("Enter number of rows and columns: ");
    scanf("%d %d", &rows, &cols);

    // ডাইনামিক 2D অ্যারে তৈরি করা
    int **matrix = (int **)malloc(rows * sizeof(int *));
    for (int i = 0; i < rows; i++) {
        matrix[i] = (int *)malloc(cols * sizeof(int));
    }

    // 2D অ্যারে ইনিশিয়ালাইজেশন
    int count = 1;
    for (int i = 0; i < rows; i++) {
        for (int j = 0; j < cols; j++) {
            matrix[i][j] = count++; // 1 থেকে n পর্যন্ত মান
        }
    }

    // 2D অ্যারের উপাদানগুলি প্রিন্ট করা
    for (int i = 0; i < rows; i++) {
        for (int j = 0; j < cols; j++) {
            printf("%d ", matrix[i][j]);
        }
        printf("\n"); // নতুন লাইনে চলে যাওয়া
    }

    // মেমরি মুক্ত করা
    for (int i = 0; i < rows; i++) {
        free(matrix[i]); // প্রতিটি সারির জন্য মেমরি মুক্ত করা
    }
    free(matrix); // প্রধান অ্যারের জন্য মেমরি মুক্ত করা

    return 0;
}
Content added By
Promotion

Are you sure to start over?

Loading...