Trang chủ Tin Học Lớp 7 NUMFINAL1 - Lại là chữ số tận cùng Dữ liệu...

NUMFINAL1 - Lại là chữ số tận cùng Dữ liệu vào: standard input Dữ liệu ra: standard output Giới hạn thời gian: 1.0 giây Giới hạn bộ nhớ: 128 megabyte Đăng bởi:

Câu hỏi :

NUMFINAL1 - Lại là chữ số tận cùng Dữ liệu vào: standard input Dữ liệu ra: standard output Giới hạn thời gian: 1.0 giây Giới hạn bộ nhớ: 128 megabyte Đăng bởi: lilom13 Cho 2 số nguyên dương a và N (a, N có giá trị từ $10^{18}$ trở lên và nhỏ hơn $10^{10.000.000}$) Tìm chữ số tận cùng của $a^{N}$ + input: gồm 2 dòng chứa 2 số a và N. + output: 1 số duy nhất là kết quả tìm được Ví dụ input 2 5 output 2 2 mũ 5 là 32, chữ số tận cùng của 32 là 2

Lời giải 1 :

- Ý tưởng:

%: phép mod (C++)
Chữ số tận cùng của `a^n = a^n % 10`
Mà `a^n % 10`
`= (a % 10)^(n % phi(10) + phi(10))` 
`= (a % 10)^(n % 4 + 4)` do `phi(10) = 4`
Để tính `n % 4` thì ta lấy 2 chữ số tận cùng của n và %4
Để tính `a % 10` thì ta lấy chữ số tận cùng của a là được

- Code: 

#include <iostream>
using namespace std;

int pw(int a, int n) {
    int res = 1;
    while (n > 0) {
        if (n & 1) res *= a, res %= 10;
        a *= a, a %= 10;
        n >>= 1;
    }
    return res;
}

int main() {
    ios::sync_with_stdio(0);
    cin.tie(0); cout.tie(0);
    
    string a, n;
    cin >> a >> n;
    
    n = '0' + n;
    
    int p = n.back() - 48;
    p = (n[n.size() - 2] - '0') * 10 + p;
    
    // phi(10) = 4
    // a^n = a^(n % phi(10) + phi(10))
    cout << pw(a.back() - 48, p % 4 + 4);
}

Thảo luận

-- AC r :v mà giải thích code giúp em với :v em đọc chả hiểu gì
-- à đợi chút
-- muốn biết tại sao lại dùng phi(10) thì e đọc ở đây v: https://cp-algorithms.com/algebra/phi-function.html#generalization
-- cậu làm pascal cho mik hiểu vs đc ko =)
-- bạn dựa vào phần trên để code đc mà :))

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

Lớp 7 - Năm thứ hai ở cấp trung học cơ sở, một cuồng quay mới lại đến vẫn bước tiếp trên đường đời học sinh. Học tập vẫn là nhiệm vụ chính!

Nguồn : ADMIN :))

Copyright © 2021 HOCTAP247