《算法笔记》3.4小节——入门模拟->日期处理 问题 C: 打印日期

问题 C: 打印日期

时间限制 : 1.000 sec 内存限制 : 32 MB

题目描述

给出年分m和一年中的第n天,算出第n天是几月几号。

输入

输入包括两个整数y(1<=y<=3000),n(1<=n<=366)。

输出

可能有多组测试数据,对于每组数据,按 yyyy-mm-dd的格式将输入中对应的日期打印出来。

样例输入 Copy

2013 60
2012 300
2011 350
2000 211

样例输出 Copy

2013-03-01
2012-10-26
2011-12-16
2000-07-29

代码

初出茅庐,请多指教!

#include<stdio.h>         

int month[13][2]={{0,0},{31,31},{28,29},{31,31},{30,30},{31,31},{30,30},{31,31},{31,31},{30,30},{31,31},{30,30},{31,31}};
int isleap(int year){
	if((year%4==0&&year%100!=0)||year%400==0) return 1;
	else return 0;
}

int main(){
	int y,n;
	int nian[1000],yue[1000],ri[1000];
	int num=0; 
	while(scanf("%d%d",&y,&n)!=EOF){
		if(y<1||y>3000||n<1||n>366){
			printf("y or n error!\n");
			break;
		}
		int m=1,d=0;
		while(n--){
			d++;
			if(d>month[m][isleap(y)]){
				m++;
				d=1;
			}
		}
		nian[num]=y;
		yue[num]=m;
		ri[num]=d;
		num++;
		//printf("%d-%02d-%02d",y,m,d);
	}
	int i;
	for(i=0;i<num;i++){
		printf("%04d-%02d-%02d\n",nian[i],yue[i],ri[i]);
	}
	return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这段代码可以进行以下优化: 1. 使用列表初始化方式数据和颜色: ```cpp static const QList<qreal> list_data = {3.1, 3.2, 3.3, 3.4, 3.5, 3.6}; static const QStringList list_pie_color = {"#6480D6","#A1DC85","#FFAD25","#FF7777","#84D1EF","#4CB383"}; ``` 使用`QList<qreal>`代替`QList<double>`,并使用`QStringList`代替`QString`数组。 2. 使用范围for循环简化代码: ```cpp for (int i = 0; i < list_data.size(); i++) { QPieSlice* pie_slice = new QPieSlice(this); pie_slice->setLabelVisible(true); pie_slice->setValue(list_data[i]); pie_slice->setLabel(QString::number(list_data[i])); pie_slice->setColor(list_pie_color[i]); pie_slice->setLabelColor(list_pie_color[i]); pie_slice->setBorderColor(list_pie_color[i]); pie_series->append(pie_slice); } ``` 可以将循环改为范围for循环,遍历`list_data`并使用其中的值和对应的颜色创建饼图切片。 3. 将部分代码移到初始化列表中: ```cpp QChart* chart = new QChart; chart->setTitle("岩性分布统计图"); chart->setTitleFont(QFont(qApp->font().family(), 16, QFont::Bold)); chart->addSeries(pie_series); chart->setAnimationOptions(QChart::SeriesAnimations); chart->legend()->setAlignment(Qt::AlignBottom); chart->legend()->setBackgroundVisible(false); ui->graphicsView_type_pie->setChart(chart); ``` 将一些操作移动到初始化列表中,使代码更简洁。 优化后的代码如下所示: ```cpp static const QList<qreal> list_data = {3.1, 3.2, 3.3, 3.4, 3.5, 3.6}; static const QStringList list_pie_color = {"#6480D6","#A1DC85","#FFAD25","#FF7777","#84D1EF","#4CB383"}; QPieSeries *pie_series = new QPieSeries(this); for (int i = 0; i < list_data.size(); i++) { QPieSlice* pie_slice = new QPieSlice(this); pie_slice->setLabelVisible(true); pie_slice->setValue(list_data[i]); pie_slice->setLabel(QString::number(list_data[i])); pie_slice->setColor(list_pie_color[i]); pie_slice->setLabelColor(list_pie_color[i]); pie_slice->setBorderColor(list_pie_color[i]); pie_series->append(pie_slice); } QChart* chart = new QChart; chart->setTitle("岩性分布统计图"); chart->setTitleFont(QFont(qApp->font().family(), 16, QFont::Bold)); chart->addSeries(pie_series); chart->setAnimationOptions(QChart::SeriesAnimations); chart->legend()->setAlignment(Qt::AlignBottom); chart->legend()->setBackgroundVisible(false); ui->graphicsView_type_pie->setChart(chart); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值