循环多少次?

Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)

Total Submission(s): 2839    Accepted Submission(s): 1028

Problem Description

  我们知道,在编程中,我们时常须要考虑到时间复杂度。特别是对于循环的部分。

比如,

假设代码中出现

for(i=1;i<=n;i++) OP ;

那么做了n次OP运算,假设代码中出现

fori=1;i<=n; i++)

  for(j=i+1;j<=n; j++) OP;

那么做了n*(n-1)/2 次OP 操作。

如今给你已知有m层for循环操作,且每次for中变量的起始值是上一个变量的起始值+1(第一个变量的起始值是1)。终止值都是一个输入的n,问最后OP有总共多少计算量。

Input

  有T组case,T<=10000。

每一个case有两个整数m和n。0<m<=2000,0<n<=2000.

Output

  对于每一个case,输出一个值,表示总的计算量,或许这个数字非常大,那么你仅仅须要输出除1007留下的余数就可以。

 

Sample Input

2

1 3

2 3

Sample Output

3

3

#include<stdio.h>
#include<string.h>
#define N 2000
int a[N+10][N+10];
void fun(){ //还是打表
int i,j;
memset(a,0,sizeof(a));
for(i=2;i<=N;i++){
a[i][1]=0;
}
for(j=1;j<=N;j++){
a[1][j]=j%1007;
}
for(i=2;i<=N;i++){
for(j=2;j<=N;j++)
a[i][j]=(a[i][j-1]+a[i-1][j-1])%1007;
}
}
int main(){
fun();
int i,T,m,n;
while(~scanf("%d",&T)){
while(T--){
scanf("%d %d",&m,&n);
printf("%d\n",a[m][n]);
}
} return 0;
}

想我所想:

解题思路:求类似这样的问题。第一次怎么样。第二次怎么样,必定存在一定的规律,或是函数关系,或是递归。耐心写下几组。甚至几十组測试数据 ,你就会发现当中的联系。

难点具体解释:找出此二维数组数据之间的规律,用两个for循环表示第一行和第一列。再用两个双重for循环打出剩余的数。然后注意这句话“或许这个数字非常大,那么你仅仅须要输出除1007留下的余数就可以”。首先。我一直对这个“除”字非常迷惑,除和除以同样吗?在小学的范围内二者是不同的,并且我还因此做错过题,受到父亲的严厉斥责,所以至今记忆犹新。

到如今我还不知道1007为何作为除数,仅仅是认为从逻辑或者说经验上来理解。应该是对1007求余。

另外。我一直纠结于if这个数字非常大,多大才算大,超出int范围吗?后来经分析调试才发现仅仅需将结果和1007求余就可以,就是这么简单。

关键词:打表     赋值

解题人:杨圣洁

解题时间:2014.8.1

解题体会:理解题意非常重要,不同学科之间有联系,也有区别。

循环多少次? 【杭电--HDOJ-1799】 附题+具体解释的更多相关文章

  1. 最小公倍数 【杭电-HDOJ-1108】 附题+具体解释

    /* 最小公倍数 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total S ...

  2. 大菲波数 【杭电-HDOJ-1715】 附题+具体解释

    /* 大菲波数 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Su ...

  3. 2^x mod n = 1 【杭电-HDOJ-1395】 附题

    /* 2^x mod n = 1 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  4. 最低位 【杭电-HDOJ-1196】 附题

    /* Lowest Bit Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) To ...

  5. 放大的X 【杭电-2655】 附题

    /* 放大的X Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Su ...

  6. 不可摸数 【杭电-HDOJ-1999】 附题

    /* hdu 1999 不可摸数 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  7. 杭电hdoj题目分类

    HDOJ 题目分类 //分类不是绝对的 //"*" 表示好题,需要多次回味 //"?"表示结论是正确的,但还停留在模块阶 段,需要理解,证明. //简单题看到就 ...

  8. 【HDU】4908 (杭电 BC #3 1002题)BestCoder Sequence ——哈希

    BestCoder Sequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Other ...

  9. HDU 6610 Game — 2019第三场杭电多校 1008题

    目录 题意 思路 AC_Code @(hdu 6610) 题意 大概说一下我理解的题意... 链接:here 你有\(n\)堆石子,每堆石子有\(a_i\)个石子.游戏规则:\(Alice\)先选择一 ...

随机推荐

  1. uva 10603

    紫皮书的例题 照着敲了一遍,非原创 大题思路主要是三杯水,而水的总数是知道的,相当于知道第一第二杯水的体积,第三杯水的体积也就确定了. 用第一第二杯水的体积来标记数组是否遍历过 优先队列来找移动体积最 ...

  2. cocos2d-x lua 内存回收

    使用cocos2d-x lua架构,游戏中存在两种内存回收方式. 1.cocos2d-x 本身内存回收 PS:假设在lua在创建一个类,继承cocos2d-x的一个类A,则该A也遵循cocos2d-x ...

  3. Firemonkey 自定义Button的Style

    这篇文章模仿HTML中基于CSS的Button,通过Style实现自定义样式的Button. 前言 主要模仿的CSS代码如下: CSS Code 123456789101112131415161718 ...

  4. vc 在edit控件中动态插入数据滚动显示

    内存从网上论坛摘抄整理 思路:给控件设置多行属性,设置垂直滚动条,Auto Vscroll设置为true,放入文本后把插入点设置到末尾 pEdit->LineScroll(pEdit->G ...

  5. CocoaPods的install和update卡在“Anylyzing dependencies”的问题解决方式[效率]

    问题 最新CocoaPod更新慢得问题,不管是运行pod install还是podupdate都卡在Anylyzing dependencies. 解决方式 事实上原因是运行两个命令时都会升级Coco ...

  6. 解决Myeclipse在port占用,导致tomcat无法启动。(Linux)

    本文来源于:http://blog.csdn.net/svitter 引文:http://www.2cto.com/os/201305/209285.html { ubuntu查看占用某port的程序 ...

  7. 联系人数据库设计之AbstractContactsProvider

    个人见解,欢迎交流. 联系人数据库设计,源代码下载请自行去android官网下载. package com.android.providers.contacts; import android.con ...

  8. Linux搭建Tomcat环境

    安装Tomcat 1)下载apache-tomcat-7.0.42.tar.gz        http://tomcat.apache.org/download-70.cgi 2)#tar -zxv ...

  9. MongoDB查询命令具体解释

    1.查询全部记录 复制代码代码例如以下: db.userInfo.find(); 相当于:select* from userInfo; 默认每页显示20条记录,当显示不下的情况下,能够用it迭代命令查 ...

  10. 阿录帮帮忙—spring mvc 的hello world

    一:web.xml配置 <!-- Spring MVC配置 --> <servlet> <servlet-name>Spring MVC Dispatcher Se ...