《实验数据的结构化程序设计》 2.4.4Calendar个人意见,寻求指引
题目大意:
制作一个日历系统,输入年份。一些周年纪念日,及服务要求日期,依据要求日期输出,输出重要程度小于发生日期的周年纪念日。
题目地址:
UVA 145
个人见解:
纯模拟,在闰年,输出顺序及输出范围可能跨年上有坑。攻克了这些后,依然困了我十多天,一直没过,求指导。
我的程序里先读入周年纪念日,l代表周年纪念日的数量,每读入一个服务日期。调用f()函数,f()函数里先计算每日期相对于当年月号的日期。然后Is()函数推断是否要输出并将要输出移至数组前方,k代表要输出的周年纪念日的数量,最后按日期。重要程度。输入先后排序,输出。
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
int d[1000],m[1000],n[1000],p[1000],q[1000];
int y,i,j,k,l;
char s[1000][255];
int Is(int i,int j)
{
int x,z;
if (n[i]>=n[0]) x=n[i]-n[0];
else x=n[i]+365+y-n[0];
if (n[j]>=n[0]) z=n[j]-n[0];
else z=n[j]+365+y-n[0];
if (x>z) return 1;
else if (x==z&&p[i]<p[j]) return 1;
else if (x==z&&p[i]==p[j]&&q[i]>q[j]) return 1;
else return 0;
}
int swap(int i,int j)
{
int t;
char c[255];
t=d[i];
d[i]=d[j];
d[j]=t;
t=m[i];
m[i]=m[j];
m[j]=t;
t=n[i];
n[i]=n[j];
n[j]=t;
t=p[i];
p[i]=p[j];
p[j]=t;
t=q[i];
q[i]=q[j];
q[j]=t;
strcpy(c,s[i]);
strcpy(s[i],s[j]);
strcpy(s[j],c);
return 0;
}
int f()
{
for (i=0;i<l;i++)
{
if (m[i]==1) n[i]=d[i];
if (m[i]==2) n[i]=31+d[i];
if (m[i]==3) n[i]=59+d[i];
if (m[i]==4) n[i]=90+d[i];
if (m[i]==5) n[i]=120+d[i];
if (m[i]==6) n[i]=151+d[i];
if (m[i]==7) n[i]=181+d[i];
if (m[i]==8) n[i]=212+d[i];
if (m[i]==9) n[i]=243+d[i];
if (m[i]==10) n[i]=273+d[i];
if (m[i]==11) n[i]=304+d[i];
if (m[i]==12) n[i]=334+d[i];
if (y&&m[i]>2) n[i]++;
}
k=1;
for (i=1;i<l;i++)
if ((n[i]>=n[0]&&n[i]-n[0]<=p[i])||(n[i]+365+y>=n[0]&&n[i]+365+y-n[0]<=p[i]))
{
swap(k,i);
k++;
}
for (i=1;i<k;i++)
for (j=i;j<k;j++)
if (Is(i,j)) swap(i,j);
printf("Today is:%3d%3d\n",d[0],m[0]);
for (i=1;i<k;i++)
{
printf("%3d%3d ",d[i],m[i]);
if (n[i]==n[0]) printf("*TODAY*");
else
{
if (n[i]>n[0])
{
for (j=0;j<p[i]+n[0]-n[i]+1;j++) printf("*");
for (j=0;j<7-(p[i]+n[0]-n[i]+1);j++) printf(" ");
}
else
{
for (j=0;j<p[i]+n[0]-n[i]-365-y+1;j++) printf("*");
for (j=0;j<7-(p[i]+n[0]-n[i]-365-y+1);j++) printf(" ");
}
}
printf(" %s\n",s[i]);
}
return 0;
}
int main()
{
char ch;
scanf("%d\n",&y);
if (y%4==0) y=1;
else y=0;
l=1;
while (scanf("%c",&ch)&& ch!='#')
{
if (ch=='A') {scanf("%d%d%d \n",&d[l],&m[l],&p[l]);gets(s[l]);q[l]=l;l++;}
if (ch=='D') {scanf("%d%d\n",&d[0],&m[0]);f();}
}
return 0;
}
版权声明:本文博主原创文章。博客,未经同意不得转载。
《实验数据的结构化程序设计》 2.4.4Calendar个人意见,寻求指引的更多相关文章
- App6种常见的数据加载设计
App6种常见的数据加载设计 设计师在进行APP设计的设计时,往往会更加专注于界面长什么样,界面和界面之间怎么跳转,给予用户什么样的操作反馈,却偏偏特别容易忽略掉一个比较重要的环节,就是APP数据加载 ...
- 面向对象和结构化程序设计的区别X
面向对象和结构化程序设计的区别 结构化程序的概念首先是从以往编程过程中无限制地使用转移语句而提出的.转移语句可以使程序的控制流程强制性的转向程序的任一处,在传统流程图中,就是用上节我们提到的" ...
- 实验一《开发环境的熟悉》&实验二《固件设计》
20145312&20145338 实验一<开发环境的熟悉>&实验二<固件设计> 合作博客链接:http://www.cnblogs.com/yx2014531 ...
- 大数据之ETL设计详解
ETL是BI项目最重要的一个环节,通常情况下ETL会花掉整个项目的1/3的时间,ETL设计的好坏直接关接到BI项目的成败.ETL也是一个长期的过程,只有不断的发现问题并解决问题,才能使ETL运行效率更 ...
- D3js初探及数据可视化案例设计实战
摘要:本文以本人目前所做项目为基础,从设计的角度探讨数据可视化的设计的方法.过程和结果,起抛砖引玉之效.在技术方案上,我们采用通用web架构和d3js作为主要技术手段:考虑到项目需求,这里所做的可视化 ...
- SAP Basis DEBUG改表数据权限角色设计
SAP Basis DEBUG改表数据权限角色设计 项目实践中,因种种原因不得不要通过debug才能解决一些特定的问题,所以就涉及到了debug权限角色的定义了. DEBUG的权限,无非就是: 1)数 ...
- java学习-初级入门-面向对象①-面向对象概述-结构化程序设计
为了学习面向对象程序设计,今天我们先利用面向对象以前的知识,设计一个学生类. 要求进行结构化程序设计. 学生类: Student 要求:存储学生的基本信息(姓名.性别.学历层次和年级),实现学生信息的 ...
- 《数字信号处理》课程实验2 – FIR数字滤波器设计
一.FIR数字滤波器设计原理 本实验采用窗函数法设计FIR数字低通滤波器.我们希望设计的滤波器系统函数如下: \(H_{d}\left( e^{jw} \right) = \left\{ \begi ...
- ArcGIS10从入门到精通系列实验图文教程(附配套实验数据持续更新)
@ 目录 1. 专栏简介 2. 专栏地址 3. 专栏目录 1. 专栏简介 本教程<ArcGIS从入门到精通系列实验教程>内容包括:ArcGIS平台简介.ArcGIS应用基础.空间数据的采集 ...
随机推荐
- c# listview导出excel文件
首先在工程中需要添加对Microsoft Excel office 11.0 object的引用 生成excel的类代码如下 using System; using System.Collection ...
- Mac OS提示# 14:自己定义文件图标
本教程的其余部分再一次错过了方法,和一些使用提示,做一些额外的,我们希望对大家有帮助. 自己定义图标 对于Mac OSX用户来说,Dashboard,Dock栏,壁纸以及各种键盘触摸板的快 ...
- nginx 区分pc和mobile 到不同的404页面
if ($http_user_agent ~* '(Android|webOS|iPhone|iPod|BlackBerry|vivo)') { set $mobile_request '1'; } ...
- symbol(s) not found for architecture i386
此问题针对百度地图真机调试和模拟器.a文件的选取问题 "$(SRCROOT)/MobileYonyou/Third/BaiduMap_IOSSDK_v2.3.0_Lib/Release$(E ...
- C# openfiledialog设置filter属性后达不到过滤效果的原因之一
此处用RichTextBox控件举例>>> 在窗体对应的类中处理Load事件可以为openfiledialog设置Filter的属性: private void Form1_Load ...
- Android大图片导致内存问题小结
在网上看了部分Android中OOM的问题,现在根据理解,做一下笔记. Android OOM 产生的几种原因 1. 程序中使用了太多自己创建的Bitmap. 这种情况通常是最好解决的. 因为你明白你 ...
- 通过memcached来实现对tomcat集群中Session的共享策略
近期在做一套集群的实现,实现的方案是在Linux下完成对Apache + Tomcat 负载均衡的功能. 上述功能已经实现,有需要了解的朋友可以看我另外一篇博文. Linux下Apache与Tomca ...
- poj3126(bfs)
题目链接:http://poj.org/problem?id=3126 题意:给两个四位数n,m,将n变成m需要多少步,要求每次只能改变n的某一位数,即改变后的数与改变前的数只有一位不同,且每次改变后 ...
- cocos2d_x_05_Box2D物理引擎
一.认识Box2D 帮助文档,共69页 二.创建一个物理世界 先导入主头文件 #include <Box2D/Box2D.h> 三.物理世界一览 像素转成米 的比例因子 就是32 三.运动 ...
- 从后台绑定数据到ligerui 的comboBox下拉框组件
这次来记录一下ligerUI的comboBox下拉框组件,ligerUI的API里也有相关描写叙述,上面都是前台写死数据,然后显示在组件中,我这次要说的是将后台的数据绑定到下拉框组件中,废话不多说. ...