Instant Complexity

Time Limit: 1000MS Memory Limit: 10000K

Description

Analyzing the run-time complexity of algorithms is an important tool for designing efficient programs that solve a problem. An algorithm that runs in linear time is usually much faster than an algorithm that takes quadratic time for the same task, and thus should be preferred.

Generally, one determines the run-time of an algorithm in relation to the `size’ n of the input, which could be the number of objects to be sorted, the number of points in a given polygon, and so on. Since determining a formula dependent on n for the run-time of an algorithm is no easy task, it would be great if this could be automated. Unfortunately, this is not possible in general, but in this problem we will consider programs of a very simple nature, for which it is possible. Our programs are built according to the following rules (given in BNF), where < number > can be any non-negative integer:

< Program > ::= “BEGIN” < Statementlist > “END”

< Statementlist > ::= < Statement > | < Statement > < Statementlist >

< Statement > ::= < LOOP-Statement > | < OP-Statement >

< LOOP-Statement > ::= < LOOP-Header > < Statementlist > “END”

< LOOP-Header > ::= “LOOP” < number > | “LOOP n”

< OP-Statement > ::= “OP” < number >

The run-time of such a program can be computed as follows: the execution of an OP-statement costs as many time-units as its parameter specifies. The statement list enclosed by a LOOP-statement is executed as many times as the parameter of the statement indicates, i.e., the given constant number of times, if a number is given, and n times, if n is given. The run-time of a statement list is the sum of the times of its constituent parts. The total run-time therefore generally depends on n.

Input

The input starts with a line containing the number k of programs in the input. Following this are k programs which are constructed according to the grammar given above. Whitespace and newlines can appear anywhere in a program, but not within the keywords BEGIN, END, LOOP and OP or in an integer value. The nesting depth of the LOOP-operators will be at most 10.

Output

For each program in the input, first output the number of the program, as shown in the sample output. Then output the run-time of the program in terms of n; this will be a polynomial of degree Y <= 10. Print the polynomial in the usual way, i.e., collect all terms, and print it in the form “Runtime = a*n^10+b*n^9+ … +i*n^2+ j*n+k”, where terms with zero coefficients are left out, and factors of 1 are not written. If the runtime is zero, just print “Runtime = 0”.

Output a blank line after each test case.

Sample Input

2
BEGIN
LOOP n
OP 4
LOOP 3
LOOP n
OP 1
END
OP 2
END
OP 1
END
OP 17
END BEGIN
OP 1997 LOOP n LOOP n OP 1 END END
END

Sample Output

Program #1

Runtime = 3*n^2+11*n+17

Program #2

Runtime = n^2+1997

Source

Southwestern European Regional Contest 1997

计算算法时间复杂度,注意处理LOOP = 0的时候。

#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <string>
#include <queue>
#include <stack>
#include <vector>
#include <algorithm> using namespace std; typedef struct node
{
int x;
int m; node *next;
}Node; void Mult(Node *Head)
{
Node *p; p=Head; while(p)
{
p->m++;
p=p->next;
}
} void Mult(Node *Head,int ans)
{
Node *p; p = Head; while(p)
{
p->x*=ans; p=p->next;
}
} void Output(Node *Head)
{
Node *p; p=Head; bool flag=false; while(p)
{
if(flag)
{
printf("+");
}
if(p->m==0&&p->x)
{
printf("%d",p->x);
flag=true;
}
else if(p->m==1&&p->x)
{
if(p->x!=1)
printf("%d*n",p->x);
else
{
printf("n");
}
flag=true;
}
else if(p->m>1&&p->x)
{
if(p->x!=1)
printf("%d*n^%d",p->x,p->m);
else
{
printf("n^%d",p->m);
}
flag=true;
} p=p->next;
} if(!flag)
{
printf("0");
}
printf("\n");
} Node * Add(Node *Head,Node *ans)
{
Node *p,*q,*t; p = ans; while(p)
{
q = Head; while(q)
{
if(p->m==q->m)
{
q->x+=p->x; break;
}
else
{
q=q->next;
}
}
if(!q)
{
t=p->next; p->next = Head; Head = p; p = t ;
}
else
{
p=p->next;
}
}
return Head;
} Node * Qsort(Node *Head)
{
Node *p,*q,*t; p = Head; while(p)
{
t=p; q=p->next; while(q)
{
if(q->m==p->m)
{
p->x+=q->x; t->next = q->next; q=t->next;
}
else
{
t=t->next; q=q->next;
}
}
p=p->next;
} p =Head; while(p)
{
q=p->next;
while(q)
{
if(p->m<q->m)
{
swap(p->m,q->m);
swap(p->x,q->x);
}
q=q->next;
}
p=p->next;
} return Head;
}
int Trans(char *s)
{
int ans = 0; for(int i=0;s[i]!='\0';i++)
{
ans = ans*10+s[i]-'0';
}
return ans;
} Node * dfs()
{
Node *Head,*ans,*p; char str[110],c[110]; Head = NULL; while(1)
{
scanf("%s",str); if(str[0]=='L')
{
scanf("%s",c); int num = -1;
if(c[0]!='n')
{
num = Trans(c);
} ans = dfs(); if(num==-1)
{
Mult(ans);
}
else if(num!=0)
{
Mult(ans,num);
}
else
{
ans = NULL;
} Head = Add(Head,ans);
}
else if(str[0]=='O')
{
scanf("%s",c); int num = Trans(c); if(num==0)
{
continue;
} p = new Node; p->x = num; p->m = 0 ; p->next = NULL; Head = Add(Head,p);
}
else if(str[0]=='E')
{
break;
}
} return Head;
} int main()
{
char str[110]; int T; int z = 1; Node *Head; scanf("%d",&T); while(T--)
{ Head = NULL; while(scanf("%s",str)&&strcmp(str,"BEGIN")!=0); Head = dfs(); Qsort(Head); printf("Program #%d\n",z++); printf("Runtime = "); Output(Head); printf("\n"); } return 0;
} /*
11
BEGIN
LOOP n
OP 4
LOOP 3
LOOP n
OP 1
END
OP 2
END
OP 1
END
OP 17
END BEGIN
OP 1997 LOOP n LOOP n OP 1 END END
END BEGIN
LOOP 0 OP 17 END
END BEGIN
LOOP n OP 0 END
END BEGIN
OP 1 LOOP n LOOP n OP 3 LOOP n OP 2 END END END
END BEGIN
LOOP n OP 1
LOOP n OP 2
LOOP n OP 3
LOOP n OP 4
LOOP n OP 5
LOOP n OP 6
LOOP n OP 7
LOOP n OP 8
LOOP n OP 9
LOOP n OP 10
END END END END END
LOOP 17 LOOP n LOOP n OP 3 END END END
END END END END END
END BEGIN LOOP 1 LOOP 2 LOOP 3 OP 1 LOOP 4 LOOP 5 LOOP 6 LOOP 7 LOOP 8 OP 1
END END END END OP 2 END END END END OP 17 END BEGIN OP 1 OP 2 OP 3 OP 4 OP 5 OP 6 OP 7 OP 8 OP 9 OP 10 OP 11 OP 12 END BEGIN LOOP n LOOP n LOOP n LOOP n LOOP n LOOP n LOOP n LOOP n LOOP n LOOP n
OP 12345 END END END END END END END END END END END BEGIN OP
17
LOOP 2
LOOP n LOOP
2 OP 4 LOOP n OP 4
LOOP n OP 5 END END OP 4 END END END END BEGIN
OP 0 LOOP n LOOP
n OP 88 OP 0 LOOP n LOOP 0 OP 17 END END END END OP 0 LOOP n LOOP 3 OP 0 END
END OP 8
END Sample Output
Program #1
Runtime = 3*n^2+11*n+17 Program #2
Runtime = n^2+1997 Program #3
Runtime = 0 Program #4
Runtime = 0 Program #5
Runtime = 2*n^3+3*n^2+1 Program #6
Runtime = 10*n^10+9*n^9+8*n^8+58*n^7+6*n^6+5*n^5+4*n^4+3*n^3+2*n^2+n Program #7
Runtime = 40391 Program #8
Runtime = 78 Program #9
Runtime = 12345*n^10 Program #10
Runtime = 20*n^3+16*n^2+32*n+17 Program #11
Runtime = 88*n^2+8
*/

Instant Complexity - POJ1472的更多相关文章

  1. POJ 1472:Instant Complexity 模拟时间复杂度

    Instant Complexity Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 1908   Accepted: 658 ...

  2. Instant Complexity(模拟,递归)

    Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 1535   Accepted: 529 Description Analyz ...

  3. POJ 1472 Instant Complexity 应该叫它编程题。。

    题目:http://poj.org/problem?id=1472 这个题目是分到“模拟题”一类的,我觉得模拟的成分比较少,主要考察编程能力.独立写完这个题特别兴奋...所以我必须好好说一说,独家哦. ...

  4. UVA 586 Instant Complexity

    给出一段程序,求运行时间. 现在只考虑一层LOOP,不妨用数组a[i]来表示n的i次方的系数.如果输入OP m,那么就在a[0]上加m,遇到END,就说明循环结束了,需要在系数上乘以循环次数.如果次数 ...

  5. 三部曲二(基本算法、动态规划、搜索)-1004-Instant Complexity

    Instant Complexity Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 20000/10000K (Java/Other) ...

  6. poj1472[模拟题]

    Instant Complexity Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 2017   Accepted: 698 ...

  7. POJ题目细究

    acm之pku题目分类 对ACM有兴趣的同学们可以看看 DP:  1011   NTA                 简单题  1013   Great Equipment     简单题  102 ...

  8. 【转】POJ百道水题列表

    以下是poj百道水题,新手可以考虑从这里刷起 搜索1002 Fire Net1004 Anagrams by Stack1005 Jugs1008 Gnome Tetravex1091 Knight ...

  9. Instant Radiosity实现

    本来说等把课程作业做完再来弄这个,但是还是没有忍住,先做了,主要原因还是这个算法很容易实现.这个算法在1997年由Keller首次提出.虽然名字叫Instant Radiosity,但是它和Radio ...

随机推荐

  1. JSON和数据集互相转换单元

    如题......只是一个单元, 为了测试JSON单元性能的... 具体测试结果参考: http://www.cnblogs.com/hs-kill/p/3668052.html 代码中用到的Seven ...

  2. PerformSelector

    PerformSelector 1. 执行和取消 //执行 [self performSelector:@selector(showMessage) withObject:nil afterDelay ...

  3. 线性时间O(n)内求数组中第k大小的数

    --本文为博主原创,转载请注明出处 因为最近做的WSN(wireless sensor network)实验要求用3个传感器节点接受2000个包的数据并算出一些统计量,其中就有算出中位数这么一个要求, ...

  4. JMeter学习-035-JMeter调试工具之二---Debug PostProcessor

    前文 JMeter学习-034-JMeter调试工具之一---HTTP Mirror Server讲述了HTTP镜像服务器在调试请求入参时的实例应用.此文我们讲述另一种测试脚本调试工具的使用. 前置处 ...

  5. maven常用插件pom配置

    一.问题描述: 部署一个maven打包项目时,jar包,依赖lib包全部手动上传至服务器,然后用maven部署报错:Exception in thread "main" java. ...

  6. Cen0S下挂载设备

    在CentOS中,如果我们要查看光驱,U盘或者要把安装包挂载到某个文件夹,我写下我的一些理解. 所谓的挂载,就是把物理设备或者文件(包含安装文件,压缩包等等),与系统中的某个目录建立一个快捷方式,然后 ...

  7. CentOS 7中防火墙 firewall-cmd命令

    在 CentOS 7 iptable 防火墙已经被 firewall替代 1.暂时开放FTP服务 firewall-cmd --add-service=ftp 2.永久开放FTP服务 firewall ...

  8. 使用Flexible适配移动端html页面 - demo记录

    前段时间看了大神的博客文章[使用Flexible实现手淘H5页面的终端适配](地址:http://www.w3cplus.com/mobile/lib-flexible-for-html5-layou ...

  9. 摘抄转载前辈们的Java集合类总结

    本文摘自 Blue Sky:http://www.cnblogs.com/hubcarl JAVA 集合类介绍和使用 类关系示意图Iterable(接口) │ └--Collection (接口) ├ ...

  10. LED将为我闪烁:控制发光二极管

      一个完整的linux驱动主要由内部处理和与硬件交互两部分组成.其中内部处理主要是指linux驱动的装载.卸载.与设备文件相关的动作处理以及业务逻辑等:与硬件交互主要是指通过iowrite32.io ...