Trang chủ Tin Học Lớp 8 Minh trong lúc rảnh rỗi đã nghĩ ra một nhiệm...

Minh trong lúc rảnh rỗi đã nghĩ ra một nhiệm vụ cho bản thân để thư giãn một chút. Anh ta chọn hai số nguyên A và B rồi tính ước số chung lớn nhất của các số n

Câu hỏi :

Minh trong lúc rảnh rỗi đã nghĩ ra một nhiệm vụ cho bản thân để thư giãn một chút. Anh ta chọn hai số nguyên A và B rồi tính ước số chung lớn nhất của các số nguyên "A giai thừa" và "B giai thừa". Minh muốn tìm ra GCD (A!, B!). Ai cũng biết rằng giai thừa của số nguyên x là tích của tất cả các số nguyên dương nhỏ hơn hoặc bằng x. Như vậy x! = 1*2*3*...*(x - 1)*x. Ví dụ 4! = 1*2*3*4 = 24. Nhắc lại rằng GCD (x, y) là số nguyên dương q lớn nhất chia (không có dư) cho cả x và y. Yêu cầu: Tìm ước chung lớn nhất của A! và B! . Dữ liệu vào: Từ tệp văn bản MAXGCD.INP gồm: • Một dòng chứa hai số nguyên A và B (1 ≤ A, B

Lời giải 1 :

- Có thể tự chứng minh: 

  + Nếu A < B `=>` GCD(A!, B!) = A!

  + Nếu A = B `=>` GCD(A!, B!) = A! = B!

  + Nếu A > B `=>` GCD(A!, B!) = B!

`=>` GCD(A!, B!) = MIN(A!, B!) = MIN(A, B)!

- Code

uses crt, math;
var a, b: longint;
const M = trunc(1e9) + 7;

function fact(n: longint): longint;
var i, ret: longint;
begin
    ret:=1;
    for i:=2 to n do ret:=(ret * i) mod M;
    exit(ret);
end;

begin
    clrscr;
    readln(a, b);
    writeln(fact(min(a, b)));
readln;
end.

Thảo luận

-- https://hoidap247.com/cau-hoi/3354713
-- https://hoidap247.com/cau-hoi/3372159
-- help https://hoidap247.com/cau-hoi/3372159
-- https://hoidap247.com/cau-hoi/3385277
-- helppp
-- https://hoidap247.com/cau-hoi/3517931

Lời giải 2 :

minh trong lúc rảnh rỗi đã nghĩ ra một nhiệm vụ cho bản thân để thư giãn một chút. Anh ta chọn hai số nguyên A và B rồi tính ước số chung lớn nhất của các số nguyên "A giai thừa" và "B giai thừa". Minh muốn tìm ra GCD (A!, B!). Ai cũng biết rằng giai thừa của số nguyên x là tích của tất cả các số nguyên dương nhỏ hơn hoặc bằng x. Như vậy x! = 1*2*3*...*(x - 1)*x. Ví dụ 4! = 1*2*3*4 = 24. Nhắc lại rằng GCD (x, y) là số nguyên dương q lớn nhất chia (không có dư) cho cả x và y.

Yêu cầu: Tìm ước chung lớn nhất của A! và B! .

Dữ liệu vào: Từ tệp văn bản MAXGCD.INP gồm:

  • Một dòng chứa hai số nguyên A và B (1 ≤ A, B < 105). Mỗi số cách nhau một khoảng trắng.

Kết quả :  Ghi ra tệp văn bản MAXGCD.OUT gồm:

  • Một số nguyên dương là ước số chung lớn nhất của các số nguyên A! và B !. Do ước chung lớn nhất của A! và B! có thể rất lớn nên ghi kết quả chia dư cho 109 + 7.

Ví dụ:

MAXGCD.INP

MAXGCD.OUT

4 3

6

Ràng buộc:

  • Có 50% test tương ứng 50% số điểm của bài với 1 ≤ A, B < 105, min (A, B) ≤ 12;
  • Có 30% test tương ứng 30% số điểm của bài với A, B ≤ 100;
  • Có 20% test khác tương ứng với 20% số điểm còn lại của bài với A, B < 105.

Ví dụ

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

Lớp 8 - Năm thứ ba ở cấp trung học cơ sở, học tập bắt đầu nặng dần, sang năm lại là năm cuối cấp áp lực lớn dần nhưng các em vẫn phải chú ý sức khỏe 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