201509-1 数列分段
问题描述
给定一个整数数列,数列中连续相同的最长整数序列算成一段,问数列中共有多少段?
输入格式
输入的第一行包含一个整数n,表示数列中整数的个数。
第二行包含n个整数a1, a2, …, an,表示给定的数列,相邻的整数之间用一个空格分隔。
输出格式
输出一个整数,表示给定的数列有多个段。
样例输入
8
8 8 8 0 12 12 8 0
样例输出
5
样例说明
8 8 8是第一段,0是第二段,12 12是第三段,倒数第二个整数8是第四段,最后一个0是第五段。
#include <iostream>
using namespace std;
int main(int argc, char** argv) {
int n,m;
cin>>n;
int a[n];
for(int i=0;i<n;i++){
cin>>a[i];
}
int count=1;
for(int j=0;j<n-1;j++){
if(a[j]!=a[j+1]){
count++;
}
}
cout<<count;
return 0;
}
201509-2 日期计算
问题描述
给定一个年份y和一个整数d,问这一年的第d天是几月几日?
注意闰年的2月有29天。满足下面条件之一的是闰年:
1) 年份是4的整数倍,而且不是100的整数倍;
2) 年份是400的整数倍。
输入格式
输入的第一行包含一个整数y,表示年份,年份在1900到2015之间(包含1900和2015)。
输入的第二行包含一个整数d,d在1至365之间。
输出格式
输出两行,每行一个整数,分别表示答案的月份和日期。
样例输入
2015
80
样例输出
3
21
样例输入
2000
40
样例输出
2
9
#include<iostream>
#include<cstring>
#include<cstdlib>
using namespace std;
bool getDay(int year);
int main(){
int year,date;
cin>>year;
cin>>date;
int month=0,day=0,i;
int a[12]={31,28,31,30,31,30,31,31,30,31,30,31};
int b[12]={31,29,31,30,31,30,31,31,30,31,30,31};
if(getDay(year)) {
for(i=0;date>0;i++){
date-=b[i];
}
cout<<i<<endl;
cout<<date+b[i-1];
}else{
for(i=0;date>0;i++){
date-=a[i];
}
cout<<i<<endl;
cout<<date+a[i-1];
}
return 0;
}
// 闰年
bool getDay(int year){
bool flag=false;
if(year%400==0||year%4==0&&year%100!=0){
flag=true;
}
return flag;
}