Trang chủ Tin Học Lớp 7 var i, n, res: longint; a: array[0..100] of longint; procedure...

var i, n, res: longint; a: array[0..100] of longint; procedure sort(l, r: longint); var i, j, x, t: longint; begin i:=l; j:=r; x:=a[(l + r) shr 1];

Câu hỏi :

var i, n, res: longint; a: array[0..100] of longint; procedure sort(l, r: longint); var i, j, x, t: longint; begin i:=l; j:=r; x:=a[(l + r) shr 1]; repeat while a[i] > x do inc(i); while a[j] < x do dec(j); if i <= j then begin t:=a[i]; a[i]:=a[j]; a[j]:=t; inc(i); dec(j); end; until i > j; if i < r then sort(i, r); if l < j then sort(l, j); end; begin readln(n); for i:=1 to n do read(a[i]); sort(1, n); // *Giảm dần* i:=2; res:=a[1] + 1; while (i <= n) and (i <= res) do begin if a[i] + i < res then res:=a[i] + i; inc(i); end; if res > n then write(n) else write(res); end. code sang c++ ạ

Lời giải 1 :

#include <iostream>
using namespace std;
int n, a[1000];

void sort(int l, int r)
{
  int i = l, j = r, x = a[(l + r) >> 1];
  do
  {
    while (a[i] > x) ++i;
    while (a[j] < x) --j;
    if (i <= j)
    {
      int t = a[i];
      a[i] = a[j];
      a[j] = t;
      ++i; --j;
    }
  } while (i <= j)
  if (i < r) sort(i, r);
  if (l < j) sort(l, j);
}

int main()
{
  cin >> n;
  for (int i = 1; i <= n; ++i) cin >> a[i];
  sort(1, n);

  int i = 2, res = a[1] + 1;
  while (i <= n && i <= res)
  {
    if (a[i] + i < res) res = a[i] + i;
    ++i;
  }
  if (res > n) cout << n;
  else cout << res;
}

Bonus: Chỉnh sửa của mình (Nếu bạn cần gọn lại, k hiểu hay sai cứ bảo mình):

#include <bits/stdc++.h>
using namespace std;
int n, a[1000];

int main()
{
  cin >> n;
  for (int i = 1; i <= n; ++i) cin >> a[i];
  sort(a+1, a+n+1, greater<int>());

  int i = 2, res = a[1] + 1;
  for (int i = 1; i <= n; ++i)
  {
    res = max(res, a[i] + i);
    if (i > res) break;
  }
  cout << min(res, n);
}

! Not debugged !

Thảo luận

Bạn có biết?

Tin học, tiếng Anh: informatics, tiếng Pháp: informatique, là một ngành khoa học chuyên nghiên cứu quá trình tự động hóa việc tổ chức, lưu trữ, xử lý và truyền dẫn thông tin của một hệ thống máy tính cụ thể hoặc trừu tượng (ảo). Với cách hiểu hiện nay, tin học bao hàm tất cả các nghiên cứu và kỹ thuật có liên quan đến việc mô phỏng, biến đổi và tái tạo thông tin.

Nguồn : Wikipedia - Bách khoa toàn thư

Tâm sự 7

Lớp 7 - Năm thứ hai ở cấp trung học cơ sở, một cuồng quay mới lại đến vẫn bước tiếp trên đường đời học sinh. Học tập vẫn là nhiệm vụ chính!

Nguồn : ADMIN :))

Liên hệ hợp tác hoặc quảng cáo: gmail

Điều khoản dịch vụ

Copyright © 2021 HOCTAPSGK