zoukankan      html  css  js  c++  java
  • CF 476 div2 C

     http://www.codeforces.com/contest/476/problem/C

     

     C. Dreamoon and Sums

    time limit per test
    1.5 seconds
    memory limit per test
    256 megabytes
    input
    standard input
    output
    standard output

    Dreamoon loves summing up something for no reason. One day he obtains two integers a and b occasionally. He wants to calculate the sum of all nice integers. Positive integer x is called nice if  and , where k is some integer number in range[1, a].

    By  we denote the quotient of integer division of x and y. By  we denote the remainder of integer division of x andy. You can read more about these operations here: http://goo.gl/AcsXhT.

    The answer may be large, so please print its remainder modulo 1 000 000 007 (109 + 7). Can you compute it faster than Dreamoon?

    Input

    The single line of the input contains two integers ab (1 ≤ a, b ≤ 107).

    Output

    Print a single integer representing the answer modulo 1 000 000 007 (109 + 7).

    Examples
    input
    1 1
    output
    0
    input
    2 2
    output
    8
    Note

    For the first sample, there are no nice integers because  is always zero.

    For the second sample, the set of nice integers is {3, 5}.

    题目大意:给你一个公式,输入a和b,对于某满足(x / b) / (x % b) = k(1 <= k <= a),问满足条件的x的总合

    思路:我们得到x/b = k * (x%b),令x%b=i,然后枚举i即可得到相应的x = i * k * b + i,

    然后即可得到暴力枚举的公式ans = ((1LL * i * ta % mod * b % mod + a * i % mod) % mod + ans) % mod,因此这种方法是O(b)的复杂度( 无语了,这里因为中间的mod爆了LL导致后来卡了一会儿,果然做事需要谨慎点。)

    当然如果把i提取出来还可以用O(1)的方法计算。

     1 //看看会不会爆int!数组会不会少了一维!
     2 //取物问题一定要小心先手胜利的条件
     3 #include <bits/stdc++.h>
     4 using namespace std;
     5 #define LL long long
     6 #define ALL(a) a.begin(), a.end()
     7 #define pb push_back
     8 #define mk make_pair
     9 #define fi first
    10 #define se second
    11 const int maxn = 100 + 5;
    12 const LL mod = 1e9 + 7;
    13 LL a, b;
    14 
    15 int main(){
    16     cin >> a >> b;
    17     LL ans = 0;
    18     LL ta = (a + 1) * a / 2 % mod;
    19     for (int i = 1; i < b; i++){
    20         ans = ((1LL * i * ta % mod * b % mod + a * i % mod) % mod + ans) % mod;
    21     }
    22     printf("%I64d
    ", ans);
    23     return 0;
    24 }
    View Code
  • 相关阅读:
    网络七层协议之部分协议详解
    C/C++书籍分享(百度网盘版)
    poi导出excel实例
    java map去除空值和null,等一些好用的工具类
    mysql查询出来的sum结果后边有.0如何去除
    java form 表单提交多条数据到后台!
    使用jsp链接jdbc数据库并将数据显示出来
    对接短信平台wsdl获取代码方式!并使用
    Flutter! 记录一下艰难的Flutter+vscode+真机,第一次调试成功
    微信公众号开发-微信公众号网页H5静默授权!!!
  • 原文地址:https://www.cnblogs.com/heimao5027/p/5799990.html
Copyright © 2011-2022 走看看