Home > C / C++ > Bài tập C++ > Tìm vị trí của phần tử lớn nhất trong mảng một chiều bằng C / C++

Tìm vị trí của phần tử lớn 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ử lớn nhất trong mảng một chiều bằng C / 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ử lớn 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(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ử lớn 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 lớn nhất thì trả về chỉ số index của nó.

Bài viết được đăng tại freetuts.net

float isIndexMax(float a[], int n){
  //gán phần tử đầu tiên cho biến max
  float max = a[0];
  //khai báo biến index là vị trí của phần tử lớn nhất
  int index;
  //sử dụng vòng lặp for để so sánh max với từng phần tử trong mảng
  //phần tử nào lớn hơn max thì gán nó cho max
  for(int i = 0; i < n; i++){
    if(a[i] < max){
      max = a[i];
      //ta gán vị trí lớn 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ử lớn 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ử lớn 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ử lớn nhất trong mảng
  printf("\nVị trí của phần tử lớn nhất là: %.1f",isIndexMax(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ử lớn nhất trong mảng */
float isIndexMax(float a[], int n){
  //gán phần tử đầu tiên cho biến max
  float max = a[0];
  //khai báo biến index là vị trí của phần tử lớn nhất
  int index;
  //sử dụng vòng lặp for để so sánh max với từng phần tử trong mảng
  //phần tử nào lớn hơn max thì gán nó cho max
  for(int i = 0; i < n; i++){
    if(a[i] < max){
      max = a[i];
      //ta gán vị trí lớn 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ử lớn 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ử lớn nhất trong mảng
  printf("\nVị trí của phần tử lớn nhất là: %.1f",isIndexMax(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ả:

bai53 01 PNG

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

Để tìm vị trí của phần tử lớn 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ử lớn nhất trong mảng */
float isIndexMax(float a[], int n){
  //gán phần tử đầu tiên cho biến max
  float max = a[0];
  //khai báo biến index là vị trí của phần tử lớn nhất
  int index;
  //sử dụng vòng lặp for để so sánh max với từng phần tử trong mảng
  //phần tử nào lớn hơn max thì gán nó cho max
  for(int i = 0; i < n; i++){
    if(a[i] > max){
      max = a[i];
      //ta gán vị trí lớn 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ử lớn 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ử lớn nhất trong mảng
  cout<<"\nVị trí của phần tử lớn nhất là: "<<isIndexMax(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ả:

bai53 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ử lớn 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 !!!

Bình luận đã đóng, nếu có thắc mắc hãy đặt câu hỏi tại hoicode.com để admin trả lời.

Nguồn: freetuts.net

Tham khảo
Tính S(n) = 1 + 2 + 3 + … + n bằng C / C++
Tính S(n) = 1^2 + 2^2 + … + n^2 bằng C / C++
Tính S(n) = 1 + 1/2 + 1/3 + … + 1/n bằng C / C++
Tính S(n) = 1/2 + 1/4 + … + 1/2n bằng C / C++
Tính S(n) = 1 + 1/3 + 1/5 + … + 1/(2n - 1) bằng C / C++
Tính S(n) = 1/(1×2) + 1/(2×3) +…+ 1/(n x (n + 1)) bằng C / C++
Tính S(n) = 1/2 + 2/3 + 3/4 + …. + n / (n + 1) bằng C / C++
Tính S(n) = 1/2 + 3/4 + 5/6 + … + (2n + 1)/( 2n + 2) bằng C / C++
Tính T(n) = 1 x 2 x 3…x N bằng C / C++
Tính T(x, n) = x^n bằng C / C++
Tính S(n) = 1 + 1.2 + 1.2.3 + … + 1.2.3….N bằng C / C++
Tính S(n) = x + x^2 + x^3 + … + x^n bằng C / C++
Tính S(n) = x^2 + x^4 + … + x^2n bằng C / C++
Tính S(n) = x + x^3 + x^5 + … + x^(2n - 1) bằng C / C++
Tính tổng tất cả các “ước số” của số nguyên dương n bằng C / C++
Tính tích tất cả các “ước số” của số nguyên dương n bằng C / C++
Liệt kê tất cả các ước số lẻ của số nguyên dương n bằng C / C++
Tính tổng tất cả các ước số chẵn của số nguyên dương n bằng C / C++
Tìm ước số lẻ lớn nhất của số nguyên dương n bằng C / C++
Đếm số lượng chữ số của số nguyên dương n bằng C / C++
Tính tích các chữ số của số nguyên dương n bằng C++
Đếm số lượng chữ số lẻ của số nguyên dương n bằng C / C++
Tính tổng các chữ số chẵn của số nguyên dương n bằng C / C++
Tìm chữ số đầu tiên của số nguyên dương n bằng C / C++
Tìm chữ số lớn nhất của số nguyên dương n bằng C / C++
Tìm chữ số nhỏ nhất của số nguyên dương n bằng C / C++
Đếm chữ số lớn nhất của số nguyên dương n bằng C / C++
Đếm chữ số nhỏ nhất của số nguyên dương n bằng C / C++
Kiểm tra số n có toàn chữ số lẻ hay không bằng C / C++
Kiểm tra số n có toàn chữ số chẵn hay không bằng C / C++
Kiểm tra các chữ số của số n có tăng dần từ trái sang phải không bằng C / C++
Kiểm tra các chữ số của số n có giảm dần hay không bằng C / C++
Tính S(x, n) = x – x^2 + x^3 + … + (-1)^n+1 * x^n bằng C / C++
Kiểm tra hai số thực có cùng dấu hay không bằng C / C++
Kiểm tra tháng thuộc quý nào bằng C / C++
Tính S(n) = 1^3 + 2^3 + … + N^3 bằng C / C++
Tìm số nguyên dương n nhỏ nhất sao cho 1 + 2 + … + n > 10000 bằng C / C++
Sử dụng vòng lặp for để xuất các ký tự từ A đến Z bằng C / C++
Tính tổng các giá trị lẻ nguyên dương nhỏ hơn N bằng C / C++
In tất cả các số nguyên dương lẻ nhỏ hơn 100 bằng C / C++
Kiểm tra loại tam giác gì bằng C / C++
Giải hệ phương trình bậc nhất hai ẩn bằng C / C++
Chương trình tìm số ngày trong tháng bằng C / C++
Nhập vào ngày tháng năm rồi in ra ngày tiếp theo bằng C / C++
Nhập vào ngày tháng năm rồi in ra ngày tháng năm trước đó bằng C / C++
In ra cách đọc của một số nguyên dương có hai chữ số bằng C / C++
In ra cách đọc của một số nguyên dương có ba chữ số bằng C / C++
Tính điểm trung bình của môn toán và môn văn bằng C / C++
Tìm phần tử lớn nhất trong mảng một chiều bằng C / C++
Tìm phần tử nhỏ nhất trong mảng một chiều bằng C / C++
Tìm vị trí của phần tử nhỏ nhất trong mảng một chiều bằng C / C++
Tìm vị trí của phần tử lớn nhất trong mảng một chiều bằng C / C++
Nhập, xuất mảng các số thực bằng C / C++
Nhập, xuất mảng các số nguyên bằng C / C++
Liệt kê các giá trị chẵn trong mảng các số nguyên bằng C / C++
Liệt kê các giá trị lẻ trong mảng các số nguyên bằng C / C++
Liệt kê vị trí các giá trị âm trong mảng một chiều các số thực bằng C / C++
Đếm số nguyên tố có trong mảng một chiều các số nguyên bằng C / C++
Tính tổng các giá trị âm trong mảng một chiều các số thực bằng C / C++

BÀI VIẾT

notice png LIST home png HOME hot gif BÁO
LỖI
top png TOP