#include <iostream>
#include <vector>
using namespace std;
int TwoPower(int n)
{
int w=1;
for(int i=0;i!=n;i++)
w=2*w;
return w;
} //2的n次方
int main()
{
int n;
cin>>n;
int days=0,Odays=0,s=0;
bool number;
vector<bool> numbers;
while(cin>>number)
{
numbers.push_back(number);
if(numbers.size()==n)
break;
}
for(vector<bool>::size_type j=0;j<n;j++)
{
if(numbers[j]==1)
{
days++;
if (days>=1&&days<3) s=s+1;
if (days>=3&&days<7) s=s+2;
if (days>=7&&days<30) s=s+3;
if (days>=30&&days<120) s=s+4;
if (days>=120&&days<365) s=s+5;
}else Odays++;
if(numbers[j+1]==1&&numbers[j]==0)
{
days=days-TwoPower(Odays-1);
if(days<0)
{
days=0;
}
Odays=0;
}
}
cout<<s;
return 0;
}
题目背景
在洛谷中,打卡不只是一个简单的鼠标点击动作,通过每天在洛谷打卡,可以清晰地记录下自己在洛谷学习的足迹。通过每天打卡,来不断地暗示自己:我又在洛谷学习了一天,进而帮助自己培养恒心、耐心、细心。此外,通过打卡,还可以获取经验值奖励,经验值的多少在一定程度上反映了你在洛谷的资历和成就。通过打卡累积活跃值,渐渐升级,会让你感觉“离神犇越来越近了”。
#include <iostream>
#include <vector>
using namespace std;
int TwoPower(int n)
{
int w=1;
for(int i=0;i!=n;i++)
w=2*w;
return w;
} //2的n次方
int main()
{
int n;
cin>>n;
int days=0,Odays=0,s=0;
bool number;
vector<bool> numbers;
while(cin>>number)
{
numbers.push_back(number);
if(numbers.size()==n)
break;
}
for(vector<bool>::size_type j=0;j<n;j++)
{
if(numbers[j]==1)
{
days++;
if (days>=1&&days<3) s=s+1;
if (days>=3&&days<7) s=s+2;
if (days>=7&&days<30) s=s+3;
if (days>=30&&days<120) s=s+4;
if (days>=120&&days<365) s=s+5;
}else Odays++;
if(numbers[j+1]==1&&numbers[j]==0)
{
days=days-TwoPower(Odays-1);
if(days<0)
{
days=0;
}
Odays=0;
}
}
cout<<s;
return 0;
}
题目描述
洛谷的打卡系统与其他网站的打卡系统一样,连续”打卡天数越多,每次打卡获得的奖励也就越多,同时连续天数加上一天。然而,于其他网站只要一天不打卡,连续天数就要清零。与其他网站不同的是,洛谷的打卡更具有人性化,如果多天不打卡,连续天数仅仅只是减少,当遗漏天数越少,减少的天数也就越少。规则是减少2^(n-1)天,n为连续遗漏天数。连续天数在下一次打卡时清算,打卡连续天数不会小于0。也就是说,如果每隔一天打卡,那么连续天数就不会变了。
当连续天数达到以下天数时,给予不同的活跃值奖励: