【题解-Acwing】AcWing 5579. 增加模数(TLE)

题目:5579. 增加模数

题目描述

给定 H 对非负整数数对 (Ai,Bi) 和一个正整数 M。

请你计算并输出 (A1B1+A2B2+...+AHBH) mod M。

输入格式

第一行包含整数 T,表示共有 T 组测试数据。

每组数据第一行包含整数 M。

第二行包含整数 H。

接下来 H 行,每行包含两个整数 Ai,Bi

输出格式

每组数据输出一行结果。

数据范围

1≤T≤100,

1≤M≤45000,

1≤H≤45000,

0≤Ai,Bi≤107,

Ai 和 Bi 不同时为 0。

时空限制

3s / 128MB

输入样例

复制代码
3
16
4
2 3
3 4
4 5
5 6
36123
1
2374859 3029382
17
1
3 18132

输出样例

复制代码
2
13195
13

代码 (TLE)

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

int T, p, H, a, b;
int res, sum;

int main(){
    scanf("%d", &T);
    while(T --){
        scanf("%d %d", &p, &H);
        res = 0;
        while(H --){
            scanf("%d %d", &a, &b);
            sum = 1 % p;
            a %= p;
            while(b){
                if(b & 1){
                    sum = sum * a % p;
                }
                b >>= 1;
                a = a * a % p;
            }
            res = (res + sum) % p;
        }
        printf("%d\n", res);
    }
    return 0;
}
相关推荐
2301_792308251 分钟前
C++与自动驾驶系统
开发语言·c++·算法
会编程的土豆2 分钟前
【数据结构与算法】LCS刷题
数据结构·算法·动态规划
无敌憨憨大王3 分钟前
最小生成树
算法
Jasmine_llq3 分钟前
《B4258 [GESP202503 一级] 四舍五入》
数据结构·算法·整数运算实现四舍五入整十数算法·批量输入遍历算法·逐行输出算法·整数算术运算组合算法·顺序输入处理算法
2401_874732536 分钟前
模板编译期排序算法
开发语言·c++·算法
weixin_421922698 分钟前
C++与Node.js集成
开发语言·c++·算法
j_xxx404_10 分钟前
力扣--分治(归并排序)算法题I:排序数组,交易逆序对的总数
数据结构·c++·算法·leetcode·排序算法
sprite_雪碧15 分钟前
排版类问题(机试高频)
c语言·数据结构·算法
暮冬-  Gentle°16 分钟前
设计模式在C++中的实现
开发语言·c++·算法
2501_9083298520 分钟前
实时音频处理C++实现
开发语言·c++·算法