UVA586 - Instant Complexity(반복 및 시뮬레이션)
제목 링크
제목 대의: 코드를 하나 드릴게요. 복잡도를 계산해 달라고요.OP은 작업을, Loop은 순환을, end는 끝을 나타냅니다.
문제풀이 사고방식: 시뮬레이션으로 돌아가다.코드를 구체적으로 보다.
코드:
#include <cstdio>
#include <cstring>
const int N = 15;
char s1[N], s2[N];
typedef long long ll;
ll nv[N];
void solve (ll * v) {
while (1) {
scanf ("%s", s1);
int num;
if (s1[0] == 'O') {
scanf ("%s", s2);
if (s2[0] != 'n') {
sscanf (s2, "%d", &num);
for (int i = 0; i < N; i++)
if (v[i])
nv[i] += v[i] * num;
} else {
for (int i = 0; i < N - 1; i++)
if (v[i])
nv[i + 1] += v[i];
}
} else if (s1[0] == 'L') {
scanf ("%s", s2);
ll tmp[N];
memset (tmp, 0, sizeof (tmp));
if (s2[0] != 'n') {
sscanf (s2, "%d", &num);
for (int i = 0; i < N; i++)
tmp[i] = num * v[i];
} else {
for (int i = 0; i < N - 1; i++)
tmp[i + 1] = v[i];
}
solve(tmp);
} else if (s1[0] == 'E')
break;
}
}
int main () {
int T, num;
scanf ("%d", &T);
for (int cas = 1; cas <= T; cas++) {
memset (nv, 0, sizeof (nv));
ll v[N];
memset (v, 0, sizeof (v));
v[0] = 1;
solve(v);
//PRINTF
printf ("Program #%d
", cas);
printf ("Runtime = ");
bool flag = 0;
for (int j = N - 1; j >= 0; j--) {
if (nv[j]) {
if (flag)
printf ("+");
if (nv[j] == 1) {
if (j == 1)
printf ("n", j);
else if (j > 1)
printf ("n^%d", j);
else
printf ("%lld", nv[j]);
} else {
if (j == 1)
printf ("%lld*n", nv[j]);
else if (j > 1)
printf ("%lld*n^%d", nv[j], j);
else
printf ("%lld", nv[j]);
}
flag = 1;
}
}
if (!flag)
printf ("0");
printf ("
");
}
return 0;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.