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. rbd cache (一)

    cache 1.why The existence of cache is based on a mismatch between the performance characteristics of ...

  2. git常用指令

    <a>github的提交方式      git status     (1)git add .--------------------存储到本地       git add -u      ...

  3. Hibernate操作指南-实体之间的关联关系(基于注解)

  4. 安装eclipse的hadoop开发环境--2

    在eclipse上做好一切,在网上很容易搜到 尝试链接hadoop集群失败,尝试单机的操作,发现# ssh localhost失败 解决ssh问题:成功解决 但是eclipse的DFS locatio ...

  5. linux----------ab--性能测试工具

    ab.exe –n 10000 –c 100 localhost/index.php //其中-n代表请求数,-c代表并发数

  6. 使用Docker构建redis集群--最靠谱的版本

    1集群结构说明 集群中有三个主节点,三个从节点,一共六个结点.因此要构建六个redis的docker容器.在宿主机中将这六个独立的redis结点关联成一个redis集群.需要用到官方提供的ruby脚本 ...

  7. vsftpd.conf

    引用:http://www.linuxidc.com/Linux/2012-08/67389.htm 研究嵌入式开发,开始使用的是Linux平台,用的是Ubuntu环境,但是发现Ubuntu的图形界面 ...

  8. 【003:switch 不加 break的结果

    #include <stdio.h> int main(){ char ch = 's'; switch(ch){ case 'a':{ printf("aaaaa") ...

  9. SqlServer 一个查询语句以致tempdb增大55G (转载)

    SqlServer 一个查询语句导致tempdb增大55G 今天操作着服务器,突然右下角提示“C盘空间不足”! 吓一跳!~ 看看C盘,还有7M!!!这么大的C盘空间怎么会没了呢?搞不好等下服务器会动不 ...

  10. 在ie与火狐的兼容性

    1.在火狐下  document.getElementById("id").textContent可以获取当前获取id下的内容   而在ie下则为:document.getElem ...