Tìm phần tử nhỏ nhất trong mảng c++

Trong bài viết này chúng ta sẽ thực hiện chương trình tìm phần tử nhỏ nhất trong mảng một chiều bằng C / C++.

Bài viết này được đăng tại freetuts.net, không được copy dưới mọi hình thức.

Mình sẽ thực hiện hai chương trình sử dụng hai ngôn ngữ khác nhau đó là ngôn ngữ C và ngôn ngữ C++. Vì vậy các bạn cần có kiến thức cơ bản về hai ngôn ngữ này đã nhé!!!

Tìm phần tử nhỏ nhất trong mảng một chiều bằng C

Đầu tiên chúng ta sẽ viết một hàm nhập với tham số truyền vào là một mảng số thực và biến n là số phần tử của mảng. Sử dụng vòng lặp do..while để yêu cầu người dùng nhập vào n > 0 và < max.

void nhap[float a[], int &n] {
  //sử dụng do..while để yêu cầu người dùng nhập vào số phần tử
  do{
    printf["\nNhập số phần tử: "];
    scanf["%d", &n];
    if[nMAX]{
      printf["\nSố phần tử không hợp lệ, xin vui lòng kiểm tra lại"];
    }
  }while[n MAX];
  //sử dụng vòng lặp for để yêu cầu người dùng nhập vào giá trị cho từng phần tử
  for[int i = 0; i < n; i++]{
    printf["Nhập a[%d]= ", i];
    scanf["%f", &a[i]];
  }
}

Tiếp đến là hàm để tìm phần tử nhỏ nhất trong mảng với tham số truyền vào là mảng float và số phần tử n. Ta thực hiện so sánh phần tử đầu tiên với từng phần tử trong mảng, sau đó xuất ra màn hình phần tử nhỏ nhất.

Bài viết này được đăng tại [free tuts .net]

float isMin[float a[], int n]{
  //gán phần tử đầu tiên cho biến min
  float min = a[0];
  //sử dụng vòng lặp for để so sánh min với từng phần tử trong mảng
  //phần tử nào nhỏ hơn min thì gán nó cho min
  for[int i = 0; i < n; i++]{
    if[a[i] < min]{
      min = a[i];
    }
  }
  //như vậy đến cuối vòng lặp ta sẽ được min là phần tử nhỏ nhất
  return min;
}

Và cuối cùng là hàm xuất các phần tử trong mảng và phần tử nhỏ nhất trong mảng ra màn hình.

void xuat[float a[], int n]{
  //xuất các phần tử trong mảng
  printf["Các phần tử trong mảng là: "];
  for[int i = 0; i < n; i++]{
    printf["%f\t",a[i]];
  }
  //xuất phần tử nhỏ nhất trong mảng
  printf["\nPhần tử nhỏ nhất là: %.1f",isMin[a,n]];
  printf["\n---------------------------------\n"];
  printf["Chương trình này được đăng tại Freetuts.net"];
}

Dưới đây là chương trình mình đã viết sẵn bằng ngôn ngữ C, các bạn có thể tham khảo nhé!!!

#include 
//khai báo biến MAX = 100
#define MAX 100
/* hàm nhập với tham số là một mảng số thực với số phần tử n */
void nhap[float a[], int &n] {
  //sử dụng do..while để yêu cầu người dùng nhập vào số phần tử
  do{
    printf["\nNhập số phần tử: "];
    scanf["%d", &n];
    if[nMAX]{
      printf["\nSố phần tử không hợp lệ, xin vui lòng kiểm tra lại"];
    }
  }while[n MAX];
  //sử dụng vòng lặp for để yêu cầu người dùng nhập vào giá trị cho từng phần tử
  for[int i = 0; i < n; i++]{
    printf["Nhập a[%d]= ", i];
    scanf["%f", &a[i]];
  }
}
/* hàm tìm phần tử nhỏ nhất trong mảng */
float isMin[float a[], int n]{
  //gán phần tử đầu tiên cho biến min
  float min = a[0];
  //sử dụng vòng lặp for để so sánh min với từng phần tử trong mảng
  //phần tử nào nhỏ hơn min thì gán nó cho min
  for[int i = 0; i < n; i++]{
    if[a[i] < min]{
      min = a[i];
    }
  }
  //như vậy đến cuối vòng lặp ta sẽ được min là phần tử nhỏ nhất
  return min;
}
/* hàm xuất */
void xuat[float a[], int n]{
  //xuất các phần tử trong mảng
  printf["Các phần tử trong mảng là: "];
  for[int i = 0; i < n; i++]{
    printf["%f\t",a[i]];
  }
  //xuất phần tử nhỏ nhất trong mảng
  printf["\nPhần tử nhỏ nhất là: %.1f",isMin[a,n]];
  printf["\n---------------------------------\n"];
  printf["Chương trình này được đăng tại Freetuts.net"];
}
/* hàm main */
int main[] {
  int n;
  float a[MAX];
  nhap[a,n];
  xuat[a,n];
}

Kết quả:

Tìm phần tử nhỏ nhất trong mảng một chiều bằng C++

Để tìm phần tử nhỏ nhất trong mảng một chiều bằng ngôn ngữ C++ ta thực hiện tương tự như ngôn ngữ C. Vì về cơ bản thì hai ngôn ngữ này khá tương đồng nhau.

Các bạn chỉ cần thay thế printf[] và scanf[] trong ngôn ngữ C bằng cout[] và cin[] trong ngôn ngữ C++. Nhớ khai báo thư viện trước khi sử dụng cout[] và cin[] nhé.

#include 
using namespace std;
//khai báo biến MAX = 100
#define MAX 100
/* hàm nhập với tham số là một mảng số thực với số phần tử n */
void nhap[float a[], int &n] {
  //sử dụng do..while để yêu cầu người dùng nhập vào số phần tử
  do{
    coutn;
    if[n  MAX]{
      cout

Bài Viết Liên Quan

Chủ Đề