Trang chủ Tin Học Lớp 11 Yêu cầu: -Làm bằng pascal -Không dùng 2 lệnh for...

Yêu cầu: -Làm bằng pascal -Không dùng 2 lệnh for lồng nhau -Giải thích cách làm(có thể ko cần nếu bài làm dài) Ai làm đúng yêu cầu và nhanh nhất sẽ đc 5*+ctlhn

Câu hỏi :

Yêu cầu: -Làm bằng pascal -Không dùng 2 lệnh for lồng nhau -Giải thích cách làm(có thể ko cần nếu bài làm dài) Ai làm đúng yêu cầu và nhanh nhất sẽ đc 5*+ctlhn nhé <3

image

Lời giải 1 :

#include <bits/stdc++.h>>
using namespace std;

#define N 100005
int n, a[N], F[N];
int m, b[N];
int main() {
    while (scanf("%d", &a[n + 1]) > 0) n++;
    for (int i = 1; i <= n; i++) {
        F[i] = lower_bound(b + 1, b + m + 1, a[i]) - b;
        m = max(m, F[i]);
        b[F[i]] = a[i];
    }
    printf("%d\n-\n", m);
    int Expected = m;
    vector<int> T;
    for (int i = n; i >= 1; i--) {
        if (F[i] == Expected) {
            T.push_back(a[i]);
            Expected--;
        }
    }
    for (int i = T.size() - 1; i >= 0; i--)
        printf("%d\n", T[i]);
}

Thảo luận

-- bài này kh làm 2 for thì b làm như nào :))
-- thế nên mk ms đi hỏi :))
-- phuong phap nay la quy hoach dong co dung 2 for di nua ma n <= 10^3 thoai mai
-- mà bài mình làm cũng chỉ đến O(nlogn) làm gì để O(n^2) kết hợp tìm kiếm nhị phân
-- ý mình là nếu dùng 2 vòng for thì mình cũng làm đc mk muốn biết là có cách khác hay ko nên mới đi hỏi đây:))
-- đấy cách mình đấy kh dùng 2 for :))) for kết hợp tìm kiếm nhị phân dpt O(nlogn)
-- à sr nhé tại mình ko đọc đc cái gì khác ngoài pascal :)) nếu bạn làm pascal là mình cho 5* liền nè
-- cái đấy mình chịu bạn tham khảo ý tưởng rồi code theo xem được kh

Lời giải 2 :

include <bits/stdc++.h>>
using namespace std;

define N 100005
int n, a[N], F[N];
int m, b[N];
int main() {
    while (scanf("%d", &a[n + 1]) > 0) n++;
    for (int i = 1; i <= n; i++) {
        F[i] = lower_bound(b + 1, b + m + 1, a[i]) - b;
        m = max(m, F[i]);
        b[F[i]] = a[i];
    }
    printf("%d\n-\n", m);
    int Expected = m;
    vector<int> T;
    for (int i = n; i >= 1; i--) {
        if (F[i] == Expected) {
            T.push_back(a[i]);
            Expected--;
        }
    }
    for (int i = T.size() - 1; i >= 0; i--)
        printf("%d\n", T[i]);

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ự 11

Lớp 11 - Năm thứ hai ở cấp trung học phổ thông, gần đến năm cuối cấp nên học tập là nhiệm vụ quan trọng nhất. Nghe nhiều đến định hướng sau này rồi học đại học. Ôi nhiều lúc thật là sợ, hoang mang nhưng các em hãy tự tin và tìm dần điều mà mình muốn là trong tương lai nhé!

Nguồn : ADMIN :))

Copyright © 2021 HOCTAP247