Trang chủ Tin Học Lớp 8 Viết chương trình tìm số M nhỏ nhất sao cho...

Viết chương trình tìm số M nhỏ nhất sao cho M! có ít nhất N chữ số 0 tận cùng Input: Số nguyên dương N (1 ≤ N ≤ 10^16). Dữ liệu luôn đảm bảo có kết quả. Outpu

Câu hỏi :

Viết chương trình tìm số M nhỏ nhất sao cho M! có ít nhất N chữ số 0 tận cùng Input: Số nguyên dương N (1 ≤ N ≤ 10^16). Dữ liệu luôn đảm bảo có kết quả. Output: Một số nguyên dương M là kết quả cần tìm.

Lời giải 1 :

uses crt;
type int = qword;
var n: int;

function calc(g: int): int;
var res: int;
begin
    res:=0;
    while g <> 0 do
        begin
            g:=g div 5;
            inc(res, g);
        end;
    exit(res);
end;

function solve(l, r: int): int;
var mid: int;
begin
    if r - l <= 1 then exit(r div 5 * 5);
    mid:=(l + r) div 2;
    if calc(mid) < n then exit(solve(mid + 1, r));
    exit(solve(l, mid));
end;

begin
    clrscr;
    readln(n);
    writeln(solve(0, 5 * n));
end.

Thảo luận

-- Giải thích giúp mình đoạn ctc solve đc ko
-- nó là chặt nhị phân đó :v

Lời giải 2 :

Cày trâu ạ 🐃🐃

#include <bits/stdc++.h>
using namespace std;
long long t,n,k,d=0,m,i;
int main()
{
 cin>>n;
 for (i=1; k<n; i++){
  m=i;
  k=0;
  while (m>0){
   m=m/5;
   k+=m;
  }
  if (d==5) d=1; else d++; 
 }
 cout<<i-1;
}

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