2013 長沙網路賽J題

2022-05-22 06:24:10 字數 1582 閱讀 1727

思路:這題對於其他能退出所有值的情況比較好像,唯一不能確定的是xxoxxoxxoxx這個形式的序列,其中xx表示未知,o表示已知。

我們令num[1]=0,那麼num[4]=sum[3]-sum[2]+num[1];

可以遞推,num[i]=sum[i-1]-sum[i-2]+num[i-3],(i%3==1)。

這樣求出來的每個num值就是相對於num[1]的值。

假使某個num[i]<0,表示第i個數相對於num[1]為負數,題目要求每個數都大於等於0,所以num[1]>=(-num[i])。

所以num[1]>=max(-num[i]).

同理可以求出所有相對於num[2]的值。

#include#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#define pb push_back

#define mp make_pair

#define maxn 100010

#define maxm 200010

#define ll __int64

#define abs(x) ((x)>0?(x):(-x))

#define lson(x) (x<<1)

#define rson(x) (x<<1|1)

#define inf 100000

#define lowbit(x) (x&(-x))

#define clr(x,y) memset(x,y,sizeof(x))

#define mod 1000000007

using

namespace

std;

intnum[maxn],sum[maxn],val[maxn];

intmain()

num[n-2]=sum[n-1]-sum[n];

for(i=n-3;i>=1;i--) if(num[i+3]>=0

)

if(num[1]>=0) num[2]=sum[1]-num[1

];

if(num[2]>=0) num[1]=sum[1]-num[2

];

for(i=4;i<=n;i++) if(num[i-1]>=0&&num[i-2]>=0

) x1=x2=0

;

for(i=4;i<=n;i+=3) if(num[i]<0

)

for(i=5;i<=n;i+=3) if(num[i]<0

) scanf("%d

",&m);

while(m--)

if(x%3==1

) printf(

"%d\n

",sum[1]-x1+val[x]);}}

return0;

}

2013 ACM ICPC 長沙網路賽J題

題意 乙個數列,給出這個數列中的某些位置的數,給出所有相鄰的三個數字的和,數列頭和尾處給出相鄰兩個數字的和。有若干次詢問,每次問某一位置的數字的最大值。分析 設數列為a1 an。首先通過相鄰三個數字的和我們可以求出a3,a6,a9 是多少。a3 sum a1,a2,a3 sum a1,a2 a6 s...

2013長沙網路賽G Goldbach

一開始以為是找規律,寫了個樸素的,沒找到規律。忘dp上想,想著想著就出思路了。一開始dp i j 表示用用i個素數的和為j的方案。把乘和加寫到一起dp i j k 在統計的時候 或 會有重複。這樣,對於2 3 5 2 5 3,3 5 2重複三次,而2 2 5只重複兩次,那麼2 2 5要多加一次。另外...

2013長沙現場賽C Collision

題意 圓的座標是 0,0 給它的半徑,再給乙個範圍半徑,再給乙個硬幣的座標和它的半徑,還有他的速度向量,問這個硬幣在給定範圍裡面待了多久。硬幣碰到圓會彈開。這道題直接畫圖推公式就好了,下面給 include include include include include include includ...