第12周 上机报告 1之练习3 回文日

简介: 题目:很诱人的一个题目:2011年11月02日是一个回文日:2011 1102,我们刚刚度过!请列出近80年和近60年还有多少个回文日(假如我们能活到百岁,你和我的……)。注意:一年只有12个月。2012年11月30日新发的程序:#include <iostream>using namespace std;int main( ){ int year,month,day

题目:很诱人的一个题目:2011年11月02日是一个回文日:2011 1102,我们刚刚度过!请列出近80年和近60年还有多少个回文日(假如我们能活到百岁,你和我的……)。注意:一年只有12个月。

2012年11月30日新发的程序:

#include <iostream>
using namespace std;
int main( )
{
	int year,month,day,y,anothery;
	bool is_cycle;
	int count=0;
	for(year = 2012; year < 2092; year++)
	{
		month=year%100; //month取到的是年的后两位
		month = (month%10)*10 + month/10; //将后两位倒过来,确定月份
		day=year/100;   //day取到的是年的前两位
		day=(day%10)*10+day/10; //将前两位倒过来,确定日期
		is_cycle =false;
		switch(month) //12个月份,各自对应合法的日期范围
		{
		case 1:
		case 3:
		case 5:
		case 7:
		case 8:
		case 10:
		case 12: if(day<=31) is_cycle =true; break;
		case 4:
		case 6:
		case 9:
		case 11: if(day<=30) is_cycle=true; break;
		case 2: if((year%4==0&&year%100!=0)||year%400==0) //闰年
				{
					if(day<=29) is_cycle =true;
				}
			else
				if(day<=28) is_cycle =true; break;
		default: continue; //后两位倒过来根本构不成月份
		}
		if(is_cycle) //能构成回文日
		{
			y=year;
			anothery=year;
			while(y>0)
			{
				anothery=anothery*10+y%10;
				y=y/10;
			}
			cout<<anothery<<endl;
			count++;
		}
	}
	cout<<"共有 "<< count <<"个回文日。"<<endl;
	return 0;
}

一楼质疑的程序
 
/* 程序头部注释开始
 * 程序的版权和版本声明部分
 * Copyright (c) 2011, 烟台大学计算机学院
 * All rights reserved.
 * 文件名称:  cycledate.cpp                           
 * 作    者:      贺利坚                       
 * 完成日期:    2011 年11月9日
 * 版本号:     v1.0    

 * 对任务及求解方法的描述部分
 * 输入描述:无
 * 问题描述:很诱人的一个题目:2011年11月02日是一个回文日:2011 1102,我们刚刚度过!列出近80年还有多少个回文日
 * 程序输出:
 * 问题分析:在近80年中,年份确定后,将其从最低位开始倒着取出,每两位组成一个单位,分别对应月份和日期部分。
 *          分别判断这些月份和日期的取值范围是否合乎要求,如果符合则输出……
 * 程序头部的注释结束 
 */
#include <iostream>
using namespace std;
int main( )
{
 int year,month,day,y,anothery;
 bool is_cycle;
 int count=0;
 for(year = 2012; year < 2092; year++)
 {
  y =year;  //后面直接用year不行吗?
  month=y;
  y=y/10;
  month = month*10 + y; //将后两位倒过来,确定月份
  y=y/10;
  day=y;
  y=y/10;
  day=day*10+y; //将前两位倒过来,确定日期
  is_cycle =false;
  switch(month) //12个月份,各自对应合法的日期范围
  {
  case 1:
  case 3:
  case 5:
  case 7:
  case 8:
  case 10:
  case 12: if(day<=31) is_cycle =true; break;
  case 4:
  case 6:
  case 9:
  case 11: if(day<=30) is_cycle=true; break;
  case 2: if((year%4==0&&year0!=0)||year@0==0) //闰年
    {
     if(day<=29) is_cycle =true;
    }
    else
     if(day<=28) is_cycle =true; break;
  default: continue; //后两位倒过来根本构不成月份
  }
  if(is_cycle) //能构成回文日
  {
   y=year;
   anothery=year;
   while(y>0)
   {
    anothery=anothery*10+y;
    y=y/10;
   }
   cout<<anothery<<endl;
   count++;
  }
 }
 cout<<"共有 "<< count <<"个回文日。"<<endl;
 return 0;
}

运行结果

经验积累:

1. 各方面要考虑周详

2. 在for循环中,用于表示年份的year只能在year++处变化,程序中再要用年份值,用其他变量临时替换

3. 变量用有意义的名称,编程过程中不会将意思搞乱

上机感言:

1. 我在程序中使用的while, for, if, switch还是很规矩的,请体会

2. 突然意识到这是个练习程序结构的好题,我做一份给大家参考吧

3. 人生苦短,你还能过9个回文日,我能过7个,这样想想,20111102多么珍贵。



目录
相关文章
|
5月前
|
C++
第十三届蓝桥杯B组C++(试题B:顺子日期)
第十三届蓝桥杯B组C++(试题B:顺子日期)
78 0
计算历史上某日为星期几
计算历史上某日为星期几
91 2
算法每日一题——第一天——统计特殊四元组
算法每日一题——第一天——统计特殊四元组
算法每日一题——第一天——统计特殊四元组
日期累加(北京理工大学考研机试题)
日期累加(北京理工大学考研机试题)
84 0
日期累加(北京理工大学考研机试题)
|
算法
算法竞赛基础题做题记录:月份天数
算法竞赛基础题:月份天数
127 1
万年之内到底有几个回文日期
刚过去的2021年12月2日,由于20211202这个数字正反顺序读都一样,被称为回文日期,引发了网友好奇,这样的日期万年之内有多少个?朋友圈甚至有鸡汤称这是第515个回文日期,让我们用Excel来算一算吧。
567 0
万年之内到底有几个回文日期
|
C++ 机器学习/深度学习
C++第11周项目3(3)——回文数
课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565 【项目3- 有趣的数字】先阅读例题,体会处理数字的一般方法,然后自行选题进行解决,掌握这种类型程序设计的一般方法。 任务:解决下面的问题(选做一道即算完成任务) (3)输入一个正整数,判断其是否为一个回文数(例1221、12321都是回文数)。 #include
1003 2
|
C++ 机器学习/深度学习 算法
2014秋C++第11周项目6参考-回文、素数
课程主页在http://blog.csdn.net/sxhelijian/article/details/39152703,课程资源在云学堂“贺老师课堂”同步展示,使用的帐号请到课程主页中查看。 【项目6-回文、素数】(1)编制一个函数reverse,返回给定数据的“反序数”,例如输入1234,输出4321。请编制reverse函数,在下面代码的基础上补充相关的部分,实现要求的功能。 int
1589 1
|
C++ 机器学习/深度学习
C++第11周项目3(4)——万以内回文数
课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565 【项目3- 有趣的数字】先阅读例题,体会处理数字的一般方法,然后自行选题进行解决,掌握这种类型程序设计的一般方法。 任务:解决下面的问题(选做一道即算完成任务) (4)输出10000以内的所有回文数。 #include&lt;iostream&gt; usin
1078 1