Dãy Lipon

Xem PDF

Điểm: 100 (p) Thời gian: 1.0s Bộ nhớ: 1G Input: bàn phím Output: màn hình

Lipon là một cậu bé đam mê toán học, cậu rất muốn khám phá ra nhưng điều mới lạ trong toán học. Một ngày nọ, cậu khám phá ra dãy số Fibonacci, Lipon càng tìm hiểu sâu hơn thì biết được dãy số ấy được tạo ra bởi Leonardo Fibonacci. Cậu ấy liền nghĩ ra một dãy số và đặt tên nó là dãy số Lipon.

Dãy số Lipon được định nghĩa như sau:

  • \(L_1\) \(=\) \(14\)
  • \(L_i\) \(=\) \((L_{i-1} * 2 + 2) \bmod 1000\)

Khi đi học lại, Lipon giới thiệu cho Anfel (người bạn thân nhất của Lipon) thì Anfel đã thử thách Lipon. Anfel cho Lipon 2 số tự nhiên \(a\)\(b\) và bảo Lipon tính tổng các số từ số thứ \(a\) đến số thứ \(b\) của dãy số Lipon trong vòng 1 giây. Vì số \(a\) và số \(b\) mà Anfel cho quá lớn nên Lipon không thể tính nhanh được, cậu nhờ các coder (trong đó có bạn) để giải hộ thử thách của Anfel.

Vì là một coder tốt bụng, bạn hãy giúp Lipon nhé.

Input

  • Dòng đầu tiên chứa hai số tự nhiên \(a\)\(b\) \((a\leq b\leq 10^{16})\)

Output

  • Dòng đầu tiên là kết quả tìm được

Subtasks

  • Subtask 1: \((a\leq b\leq 10^{5})\) (40% số điểm)
  • Subtask 2: \((a\leq b\leq 10^{16})\) (60% số điểm)

Example

Test 1
Input
1 10
Output
1348

Bình luận

  • ducmatgoclyhoa 7:06 p.m. 12 Tháng 10, 2024

    Hint: Dãy L là dãy kết quả của thuật toán LCG nên nó có tính chất lặp tuần hoàn, tức tồn tại giá trị \(T\) để \(L[x - T] = L[x]\) với mọi \(x >= T\)\(T <= (số \ mod \ của \ L)\) hay \(T <= 1000\) nên có thể chạy trâu tìm ra \(T\)

    Giá trị của T

    \(T = 100\)

    1 chu kì của dãy L (tức sau đó sẽ lặp lại từ giá trị đầu tiên)

    l: list[int] = [14, 30, 62, 126, 254, 510, 22, 46, 94, 190, 382, 766, 534, 70, 142, 286, 574, 150, 302, 606, 214, 430, 862, 726, 454, 910, 822, 646, 294, 590, 182, 366, 734, 470, 942, 886, 774, 550, 102, 206, 414, 830, 662, 326, 654, 310, 622, 246, 494, 990, 982, 966, 934, 870, 742, 486, 974, 950, 902,
    806, 614, 230, 462, 926, 854, 710, 422, 846, 694, 390, 782, 566, 134, 270, 542, 86, 174, 350, 702, 406, 814, 630, 262, 526, 54, 110, 222, 446, 894,
    790, 582, 166, 334, 670, 342, 686, 374, 750, 502, 6]

    • lehongduc 11:35 p.m. 13 Tháng 7, 2024 chỉnh sửa 2

      nếu cái này bảo tính một số thì mình đã tìm ra quy luật nhưng nó bảo tính tổng từ 1->10^16 thì chịu :v

      quy luật

      14*pow(2,n-1)+pow(2,n-1)+pow(2,n-2)+... cho đến khi n=0
      thêm lũy thừa nhị phân và mod cho 1000 nữa nha!

      • iq2000laday 9:13 a.m. 14 Tháng 6, 2024

        Đệ quy hả anh em 🙂

        • mapubzz 9:32 p.m. 30 Tháng 4, 2024

          sao kết quả của test lại ra 1348 , mình tưởng mod 1000 thì kết quả phải nhỏ hơn 1000 chứ