SIMPLE
STRING
ARRAY
SORTING
POINTER
CALCULATION
NUMBER
OTHER
CÁC CHỦ ĐỀ
BÀI MỚI NHẤT
MỚI CẬP NHẬT

Tìm vị trí của phần tử nhỏ nhất trong mảng một chiều bằng C / C++

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

test php

banquyen png
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 với 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 vị trí của 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à < min.

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(n<=0 || n>MAX){
      printf("\nSố phần tử không hợp lệ, xin vui lòng kiểm tra lại");
    }
  }while(n<=0 || 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 ta viết hàm để tìm ra vị trí của phần tử nhỏ nhất trong mảng với tham số là một mảng các số thực a[ ] và số phần tử n. Ta thực hiện so sánh phần tử đầu tiên trong mảng với các phần tử còn lại, phần tử nào nhỏ nhất thì trả về chỉ số index của nó.

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

float isIndexMin(float a[], int n){
  //gán phần tử đầu tiên cho biến min
  float min = a[0];
  //khai báo biến index là vị trí của phần tử nhỏ nhất
  int index;
  //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];
      //ta gán vị trí nhỏ nhất cho index
      index = i;
    }
  }
  //như vậy đến cuối vòng lặp ta sẽ được index là vị trí của phần tử nhỏ nhất
  return index;
}

Và cuối cùng ta cần một hàm xuất để hiển thị các phần tử trong mảng cùng với đó là chỉ số index của phần tử nhỏ nhất trong mảng.

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 vị trí của phần tử nhỏ nhất trong mảng
  printf("\nVị trí của phần tử nhỏ nhất là: %.1f",isIndexMin(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 <stdio.h>
//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(n<=0 || n>MAX){
      printf("\nSố phần tử không hợp lệ, xin vui lòng kiểm tra lại");
    }
  }while(n<=0 || 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 vị trí index của phần tử nhỏ nhất trong mảng */
float isIndexMin(float a[], int n){
  //gán phần tử đầu tiên cho biến min
  float min = a[0];
  //khai báo biến index là vị trí của phần tử nhỏ nhất
  int index;
  //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];
      //ta gán vị trí nhỏ nhất cho index
      index = i;
    }
  }
  //như vậy đến cuối vòng lặp ta sẽ được index là vị trí của phần tử nhỏ nhất
  return index;
}
/* 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 vị trí của phần tử nhỏ nhất trong mảng
  printf("\nVị trí của phần tử nhỏ nhất là: %.1f",isIndexMin(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ả:

bai52 01 PNG

Tìm vị trí của phần tử nhỏ nhất trong mảng một chiều bằng C++

Để tìm vị trí của 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 <iostream> trước khi sử dụng cout() và cin() nhé.

#include <iostream>
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{
    cout<<"\nNhập số phần tử: ";
    cin>>n;
    if(n <= 0 || n > MAX){
      cout<<"\nSố phần tử không hợp lệ, xin vui lòng kiểm tra lại";
    }
  }while(n<=0 || 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++){
    cout<<"Nhập a["<<i<<"]= ";
    cin>>a[i];
  }
}
/* hàm tìm vị trí index của phần tử nhỏ nhất trong mảng */
float isIndexMin(float a[], int n){
  //gán phần tử đầu tiên cho biến min
  float min = a[0];
  //khai báo biến index là vị trí của phần tử nhỏ nhất
  int index;
  //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];
      //ta gán vị trí nhỏ nhất cho index
      index = i;
    }
  }
  //như vậy đến cuối vòng lặp ta sẽ được index là vị trí của phần tử nhỏ nhất
  return index;
}
/* hàm xuất */
void xuat(float a[], int n){
  //xuất các phần tử trong mảng
  cout<<"Các phần tử trong mảng là: ";
  for(int i = 0; i < n; i++){
    cout<<a[i]<<"\t";
  }
  //xuất vị trí của phần tử nhỏ nhất trong mảng
  cout<<"\nVị trí của phần tử nhỏ nhất là: "<<isIndexMin(a,n);
  cout<<"\n---------------------------------\n";
  cout<<"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ả:

bai52 02 PNG

Như vậy là chúng ta đã thực hiện xong chương trình tìm vị trí của phần tử nhỏ nhất trong mảng một chiều bằng C / C++. Các bạn có thể tham khảo các bài tập khác tại Tổng hợp 1000 bài tập C / C++ nhé, chúc các bạn thành công !!!

Câu hỏi thường gặp liên quan:

Cùng chuyên mục:

Các hàm xử lý số thực (float.h) trong C/C++

Các hàm xử lý số thực (float.h) trong C/C++

Các hàm xử lý số nguyên lớn (bigint.h) trong C/C++

Các hàm xử lý số nguyên lớn (bigint.h) trong C/C++

Các hàm xử lý thời gian (time.h) trong C

Các hàm xử lý thời gian (time.h) trong C

Các hàm xử lý chuỗi (string.h) trong C/C++

Các hàm xử lý chuỗi (string.h) trong C/C++

Thread Pools và Parallel Algorithms trong C++

Thread Pools và Parallel Algorithms trong C++

Tạo và quản lý các Multithreading trong C++

Tạo và quản lý các Multithreading trong C++

Xử lý ngoại lệ khi làm việc với Memory Allocation trong C++

Xử lý ngoại lệ khi làm việc với Memory Allocation trong C++

Try, Catch, và Throw của Exception Handling trong C++

Try, Catch, và Throw của Exception Handling trong C++

Cách sử dụng Lambda Expressions trong C++

Cách sử dụng Lambda Expressions trong C++

Sử dụng weak_ptr trong C++

Sử dụng weak_ptr trong C++

Sử dụng shared_ptr trong C++

Sử dụng shared_ptr trong C++

Sử dụng unique_ptr trong C++

Sử dụng unique_ptr trong C++

Tổng quan về Smart Pointers trong C++

Tổng quan về Smart Pointers trong C++

Sử dụng Iterators trong STL của C++

Sử dụng Iterators trong STL của C++

[Iterator] Sử dụng Vector trong C++

[Iterator] Sử dụng Vector trong C++

[Iterator] Sử dụng trong List trong C++

[Iterator] Sử dụng trong List trong C++

[STL] Sử dụng Vector trong C++

[STL] Sử dụng Vector trong C++

Tổng quan về Iterators trong C++

Tổng quan về Iterators trong C++

[STL] Các hàm thường dùng của lớp Vector trong C++

[STL] Các hàm thường dùng của lớp Vector trong C++

[STL] Các hàm thông dụng của Map trong C++

[STL] Các hàm thông dụng của Map trong C++

Top