Trang chủ Tin Học Lớp 9 Cho mình hỏi bài này có cách làm nào tối...

Cho mình hỏi bài này có cách làm nào tối ưu hơn cách làm của mình không ạ? Giải thích một chút về hướng làm của mình thì mình sẽ tìm chữ cái có giá trị ASCII l

Câu hỏi :

Cho mình hỏi bài này có cách làm nào tối ưu hơn cách làm của mình không ạ? Giải thích một chút về hướng làm của mình thì mình sẽ tìm chữ cái có giá trị ASCII lớn nhất trùng nhau trong 2 xâu (bằng sắp xếp và diệt trâu :v), rồi mình xét từ vị trí chữ cái đó + 1 theo cách trên cho đến khi kết quả trả về là -1 (không có kí tự nào trùng nhau nữa) thì mình dừng chương trình và in ra xâu vừa tìm được Nếu được thì mong mn có thể viết code mẫu luôn cho mình (pascal hoặc C++ đều OK) và giải thích code hộ mình luôn Ý kiến nào mình thấy hay mình sẽ vote 5 sao ạ, cảm ơn mn.

image

Lời giải 1 :

Gọi $f_{i, j}$ là độ dài xâu con chung dài nhất xâu $S1(i)$ ($i$ kí tự đầu của $S1$) và xâu $S2(j)$ ($j$ kí tự đầu của $S2$)

Công thức truy hồi:

$\left \{ {{f_{i, j}=f_{i-1, j-1} \text{+1 Nếu } S1_i=S2_j} \atop {f_{i, j}=max(f_{i, j-1}, f_{i-1, j}) \text{ Nếu } S1_i!=S2_j}} \right.$

Cơ sở: $f_{0, j} = f_{i, 0} = 0$

Code C++: 

#include<bits/stdc++.h>
#define int int64_t
using namespace std;
string a, b, s;
int f[260][260], m, n, k;
signed main()
{
 ios::sync_with_stdio(0);
 cin.tie(0); cout.tie(0);
 cin >> a >> b;
 m = a.size();
 n = b.size();
 a = ' ' + a;
 b = ' ' + b;
 for (int i = 1; i <= m; ++i)
    {
        for (int j = 1; j <= n; ++j)
        {
            if(a[i] == b[j])
            {
                f[i][j] = f[i - 1][j - 1] + 1;
            }
            else
            {
                f[i][j] = max(f[i - 1][j], f[i][j - 1]);
            }
        }
    }
    k = f[m][n];
    s = "";
    while (k > 0)
    {
        if(a[m] == b[n])
        {
            s = a[m] + s;
            k--; m--; n--;
        }
        else
        {
            if(f[m - 1][n] == k) m--;
            if(f[m][n - 1] == k) n--;
        }
    }
    cout << s.size() << '\n' << s;
 return 0;
}

Thảo luận

-- bạn ơi bạn nhầm yêu cầu đề bài rồi, cái này là xâu con chung dài nhất mak

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

Lớp 9 - Là năm cuối ở cấp trung học cơ sở, sắp phải bước vào một kì thi căng thẳng và sắp chia tay bạn bè, thầy cô và cả kì vọng của phụ huynh ngày càng lớn mang tên "Lên cấp 3". Thật là áp lực nhưng các em hãy cứ tự tin vào bản thân là sẻ vượt qua nhé!

Nguồn : ADMIN :))

Copyright © 2021 HOCTAP247