循环多少次? 【杭电--HDOJ-1799】 附题+具体解释
循环多少次?
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】 附题+具体解释的更多相关文章
- 最小公倍数 【杭电-HDOJ-1108】 附题+具体解释
/* 最小公倍数 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total S ...
- 大菲波数 【杭电-HDOJ-1715】 附题+具体解释
/* 大菲波数 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Su ...
- 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) ...
- 最低位 【杭电-HDOJ-1196】 附题
/* Lowest Bit Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) To ...
- 放大的X 【杭电-2655】 附题
/* 放大的X Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Su ...
- 不可摸数 【杭电-HDOJ-1999】 附题
/* hdu 1999 不可摸数 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- 杭电hdoj题目分类
HDOJ 题目分类 //分类不是绝对的 //"*" 表示好题,需要多次回味 //"?"表示结论是正确的,但还停留在模块阶 段,需要理解,证明. //简单题看到就 ...
- 【HDU】4908 (杭电 BC #3 1002题)BestCoder Sequence ——哈希
BestCoder Sequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Other ...
- HDU 6610 Game — 2019第三场杭电多校 1008题
目录 题意 思路 AC_Code @(hdu 6610) 题意 大概说一下我理解的题意... 链接:here 你有\(n\)堆石子,每堆石子有\(a_i\)个石子.游戏规则:\(Alice\)先选择一 ...
随机推荐
- Delphi XE2 升级项目编译ralease版本,无法添加UAC解决方法
我今天把一个原来是Delphi2007的工程升级到了Delphi XE2,在编译ralease版本时候,发现无法添加UAC,我觉得可能是升级的原因,随后我用XE2新建了一个工程,但是在编译raleas ...
- OCA读书笔记(1) - 浏览Oracle数据库架构
Objectives: List the major architectural components of Oracle DatabaseExplain the memory structuresD ...
- 【Demo 0001】Android 程序结构
Android 学习步骤及内容: 1. Android 程序结构(开发环境搭建,Android第一程序,程序启动过程以及工程介绍): 2. Android 事件(通用使用规则,通用 ...
- C++基础之二:常量指针和指针常量
1.常量指针 定义:具有只能够读取内存中数据,却不能够修改内存中数据的属性的指针,称为指向常量的指针,简称常量指针. 声明:const int * p; 注:可以将一个常量的地址赋值给一个对应类型的常 ...
- c++在string类源
一:回想 (1)c++中的string类是在面试中和笔试中常常考的题目: project代码免费下载 string类的自行实现 (2)c++中的string类和fstream类合起来是处理外部数据的利 ...
- 积累的VC编程小技巧之工具条和状态条
1.工具条和状态条中控件的添加: 方法⑴.只能在ToolBar里创建控件:首先,在ToolBar中创建一个Button,其ID为ID_TOOL_COMBO(我们要将创建的控件放在该Button的位置上 ...
- 【Demo 0002】Java基础-语句
本章学习要点: 1. 掌握Java关健语句使用方法; 2. 理解与语句相关的关键字用法; 一.Java 关键语句 Java语句以及关联关键字与C完全相 ...
- 提高mysql memory(heap) engine内存性能的开源补丁_XMPP Jabber即时通讯开发实践_百度空间
提高mysql memory(heap) engine内存性能的开源补丁_XMPP Jabber即时通讯开发实践_百度空间 提高mysql memory(heap) engine内存性能的开源补丁
- tbb 线程安全concurrent_queue的性能
tbb实现了线程安全的queue,这样程序员既可以不用和那些lock,mutex,criticalsection打交道,又大大提高性能,太给力了..比较的结果见代码中的注释.结果可以看出代码足足少一半 ...
- lua 函数回调技巧
技巧1: local a = {}; function b() print("Hello World") end a["sell"] = {callFunc = ...