Trang chủ Tin Học Lớp 9 cần ý tưởng+thuật toán. Yêu cầu dưới 2s khi chạy...

cần ý tưởng+thuật toán. Yêu cầu dưới 2s khi chạy CT Đếm số nguyên dương không quá N mà chia hết cho A hoặc B. Mô tả đầu vào Dòng duy nhất chứa 3 số nguyên dươn

Câu hỏi :

cần ý tưởng+thuật toán. Yêu cầu dưới 2s khi chạy CT Đếm số nguyên dương không quá N mà chia hết cho A hoặc B. Mô tả đầu vào Dòng duy nhất chứa 3 số nguyên dương N, A và B. Ràng buộc 0

Lời giải 1 :

Code C++

#include <bits/stdc++.h>
using namespace std;
int main()
{
 unsigned long long n, a, b, lcm, boia, boib, boilcm;
 cin >> n >> a >> b;
 boia = n / a;
 boib = n / b;
 lcm = (a * b) / __gcd(a, b);
 boilcm = n / lcm;
 cout << boia + boib - boilcm;
}

=============================

Code pascal

program Hello;
uses crt;
var n, a, b: int64;
function gcd(a, b: Int64): Int64;
var
  temp: Int64;
begin
  while b <> 0 do
  begin
    temp := b;
    b := a mod b;
    a := temp
  end;
  gcd:= a
end;
function dem(a, b, n: int64): int64;
var lcm, boia, boib, boilcm: int64;
begin
    boia:= n div a;
    boib:= n div b;
    lcm:= (a * b) div gcd(a,b);
    boilcm:= n div lcm;
    dem:= boia + boib - boilcm;
end;
begin
    readln(n, a, b);
    writeln(dem(a, b, n));
end.

==================================

Ý tưởng:

Đếm số lượng bội của A: boia = N / A.

Đếm số lượng bội của B: boib =N / B.

Sau đó cộng lại được số lượng bội của A hoặc B. Nhưng trong đó có các số bị trùng nhau.

Như N = 6, A = 2, B = 3. 

Thì 6 / 2 + 6 / 3 = 3 + 2 = 5. ( 2, 4, 6, 3, 6)

Như vậy ta bị dư một số 6, mà ta thấy 6 là bội chung nhỏ nhất của cả A và B nên, ta cần trừ nó đi.

Tìm bội chung nhỏ nhất của A và B: lcm = (A * B) / gcd(A, B). (gcd là ước chung lớn nhất)

Đếm số lượng bội của lcm: boilcm = N / lcm.

Như vậy số lượng bội của A và B không lớn hơn N là:

boia + boib - boilcm

==================

Trong hình có thời gian chạy code nhé.

image
image
image
image

Thảo luận

Lời giải 2 :

- Ý tưởng:

+ Tính xem có bao nhiêu số trong khoảng [1..n] chia hết cho a : n//a

+ Tính xem có bao nhiêu số trong khoảng [1..n] chia hết cho b : n//b

+ Tính xem có bao nhiêu số bị đếm 2 lần ( chia hết cho cả a và b ) để giảm đi : n//( (a*b)/gcd(a*b) )

  * Nháp thử vài lần là biết thôi :D

- Code c++:

#include <bits/stdc++.h>
#define ull unsigned long long
using namespace std;

int main()
{
 int n,a,b;
 cin >> n >> a >> b;
 int ta = n/a;
 int tb = n/b;
 int tab = n/((a*b)/__gcd(a,b));
 cout << ta+tb-tab;
}

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 :))

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

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

Copyright © 2021 HOCTAPSGK