热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

用c写的简单的日历(学习模块划分)

简单日历​主要目的是学习函数模块划分,成品大概是这样,加了一些花里胡哨的东西(▽\)分三


简单日历

​ 主要目的是学习函数模块划分,成品大概是这样,加了一些花里胡哨的东西(/▽\)



分三个模块,主函数.c 显示.c 计算.c 与.h 文件

有两种实现方式,区别在于是否以数组在模块之间传递。


第一种-用数组进行保存日历页

输入信息并控制

#define _CRT_SECURE_NO_WARNINGS
#include
#include "calendar1.h"
#include
#include
#define ON 1
#define OFF 0
int main( )
{
int year = 2019;
int mOnth= 7;
char op[10] = { 0 };
int button = 1;
do
{
calen_cal(year,month);
calen_display(year, month,button);
scanf(" %s", op);
if( !strcmp(op, "ON") ) {
button = 1; continue;
}
if( !strcmp(op, "OFF") ) {
button = 0; continue;
}
if( *op == "U" || *op == "u" )
{
if( mOnth== 1 )
{
--year;
mOnth= 12;
}
else --month;
continue;
}
if( *op == "D" || *op == "d" )
{
if( mOnth== 12 )
{
++year;
mOnth= 1;
}
else ++month;
continue;
}
if( *op == "R" || *op == "r" )break;

printf("请按以下格式输入:2019-7
");
int temY, temM;
scanf("%d-%d", &temY, &temM);
if( is_right(temY, temM) )
{
year = temY; mOnth= temM;
}
} while( true );
}

计算( •̀ ω •́ )✧

​```c
#include
#include "calendar.h"
int months[12] = { 31,28,31,30,31,30,31,31,30,31,30,31 };
int is_leepyear(int year)//是否为闰年
{
return ( year % 4 == 0 && year % 100 != 0 || year % 400 == 0 );
}
int is_right(int year, int mon) //输入的年份或月份是否正确
{
return ( year > 1900 && mon <= 12 && mon >= 1 );
}
int first_day_index(int year, int mon)//返回该月第一天的下标 0-6
{
if( is_leepyear(year) )months[1] = 29;
else months[1] = 28;
int days = 0;
for( int i = mon - 1; i > 0; --i )
{
days += months[i - 1];
}
for( int i = year - 1; i >= 1900; --i )
{
if( i % 4 == 0 && i % 100 != 0 || i % 400 == 0 ) days += 366;
else days += 365;
}
return days % 7;
}
int Last_days(int year, int mon)// 返回上个月最后一天的天数,用来排日历中的上一月信息
{
if( mon == 1 )return 31;
else return months[mon - 2];
}
void calen_cal(int *calen,int year,int mon,int index)//将排好的信息放到数组中
{
int Last_day = Last_days(year, mon);
int count = 0;
//排上个月
for( int i = 1; i <= index; ++i, ++count )
{
calen[count]=Last_day - index + i;
}
//排本月
for( int i = 1; i <= months[mon - 1]; ++i, ++count )
{
calen[count] = i;
}
//排下月
for( int i = 1; count <42; ++i, ++count )
{
calen[count] = i;
}
}
​```

花里胡哨的显示

​```c
#include
#include
#include "calendar.h"
void calen_print(int *calen, int button, int index)
{
//打印上一月
int i = 0;
for( i = 1; i <= index; ++i )
{
if( button == 1 )printf("%5d", calen[i - 1]);
else printf(" ");
if( i % 7 == 0 )putchar(10);
}
//打印本月
for( ; calen[i - 1] != 1; ++i )
{
printf("%5d", calen[i - 1]);
if( i % 7 == 0 )putchar(10);
}
//打印下一月
for( ; i <= 42; ++i )
{
if( button == 1 )printf("%5d", calen[i - 1]);
else printf(" ");
if( i % 7 == 0 )putchar(10);
}
}
void calen_ui(int *calen, int button, int index,int year,int mon)
{
system("cls");
//这块是更改控制台颜色
srand(time(NULL));
int rand_color;
HANDLE hCOnsole= GetStdHandle(STD_OUTPUT_HANDLE);
//
rand_color = rand( ) % 14;
SetConsoleTextAttribute(hConsole, rand_color);
printf("%d-%d U/D
", year, mon);
rand_color = rand( ) % 14;
SetConsoleTextAttribute(hConsole, rand_color);
printf("Mon Tue Wed Thu Fri Sat Sun
");
rand_color = rand( ) % 14;
SetConsoleTextAttribute(hConsole, rand_color);
printf("--------------------------------------
");
rand_color = rand( ) % 14;
SetConsoleTextAttribute(hConsole, rand_color);
calen_print(calen, button,index);
rand_color = rand( ) % 14;
SetConsoleTextAttribute(hConsole, rand_color);
printf("--------------------------------------
");
rand_color = rand( ) % 14;
SetConsoleTextAttribute(hConsole, rand_color);
printf("U/u 向上翻页,D/d向下翻页,R/r退出,ON/OFF是否显示其他天数,输入其他进入日期跳转模式
");

rand_color = rand( ) % 14;
SetConsoleTextAttribute(hConsole, rand_color);
}
​```

头文件声明

​```c
void calen_ui(int *calen, int button, int index, int year, int mon);
void calen_cal(int *calen, int year, int mon,int index);
int first_day_index(year, mon);
​```


推荐阅读
  • 本文详细介绍了在 Vue.js 前端框架中集成 vue-i18n 插件以实现多语言支持的方法。通过具体的配置步骤和示例代码,帮助开发者快速掌握如何在项目中实现国际化功能,提升用户体验。同时,文章还探讨了常见的多语言切换问题及解决方案,为开发人员提供了实用的参考。 ... [详细]
  • 本文深入解析了Java面向对象编程的核心概念及其应用,重点探讨了面向对象的三大特性:封装、继承和多态。封装确保了数据的安全性和代码的可维护性;继承支持代码的重用和扩展;多态则增强了程序的灵活性和可扩展性。通过具体示例,文章详细阐述了这些特性在实际开发中的应用和优势。 ... [详细]
  • PHP服务接口的专业测试方法与实践 ... [详细]
  • 总数 | 小规模算法动态规划第3讲:LeetCode 62 不同路径详解 | 从自顶向下到自底向上的动态规划方法分析
    总数 | 小规模算法动态规划第3讲:LeetCode 62 不同路径详解 | 从自顶向下到自底向上的动态规划方法分析 ... [详细]
  • 探索偶数次幂二项式系数的求和方法及其数学意义 ... [详细]
  • 本文深入探讨了C#中的反射与特性功能。首先,介绍了反射的基本概念,即通过元数据(包括类的方法、属性和字段等)在运行时动态获取和操作程序信息的能力。此外,还详细解析了特性的使用方法及其在代码注解和元数据扩展中的重要作用,为开发者提供了丰富的编程技巧和实践指导。 ... [详细]
  • 在使用 SQL Server 时,连接故障是用户最常见的问题之一。通常,连接 SQL Server 的方法有两种:一种是通过 SQL Server 自带的客户端工具,例如 SQL Server Management Studio;另一种是通过第三方应用程序或开发工具进行连接。本文将详细分析导致连接故障的常见原因,并提供相应的解决策略,帮助用户有效排除连接问题。 ... [详细]
  • AIX编程挑战赛:AIX正方形问题的算法解析与Java代码实现
    在昨晚的阅读中,我注意到了CSDN博主西部阿呆-小草屋发表的一篇文章《AIX程序设计大赛——AIX正方形问题》。该文详细阐述了AIX正方形问题的背景,并提供了一种基于Java语言的解决方案。本文将深入解析这一算法的核心思想,并展示具体的Java代码实现,旨在为参赛者和编程爱好者提供有价值的参考。 ... [详细]
  • 无论是计算机专业学生还是非计算机专业的学习者,在掌握C语言的过程中可能会遇到诸多挑战,不清楚从何入手。为此,本文系统地梳理了2019年福建省C语言的核心知识点,并结合最新的技术进展进行了详细总结,旨在为初学者提供全面的学习指导。文章不仅涵盖了基础语法和数据结构,还深入探讨了指针、内存管理和算法优化等高级主题,帮助读者快速提升编程能力。 ... [详细]
  • 深入解析C语言中的动态规划算法:以背包问题为例
    本文深入探讨了C语言中动态规划算法的应用,以经典的背包问题为例进行详细解析。通过实例分析,展示了如何利用动态规划解决复杂优化问题,并提供了高效的代码实现方法。文章不仅涵盖了算法的基本原理,还讨论了其在实际编程中的应用技巧和优化策略,为读者提供了全面的理解和实践指导。 ... [详细]
  • 2012年9月12日优酷土豆校园招聘笔试题目解析与备考指南
    2012年9月12日,优酷土豆校园招聘笔试题目解析与备考指南。在选择题部分,有一道题目涉及中国人的血型分布情况,具体为A型30%、B型20%、O型40%、AB型10%。若需确保在随机选取的样本中,至少有一人为B型血的概率不低于90%,则需要选取的最少人数是多少?该问题不仅考察了概率统计的基本知识,还要求考生具备一定的逻辑推理能力。 ... [详细]
  • JavaScript XML操作实用工具类:XmlUtilsJS技巧与应用 ... [详细]
  • Spring框架的核心组件与架构解析 ... [详细]
  • 在编程笔试和面试中,全排列算法因其适中的难度而备受青睐,不仅能够考察应聘者的算法基础,还能测试其对递归和回溯的理解。本文将深入解析全排列算法的实现原理,探讨其应用场景,并提供优化建议,帮助读者更好地掌握这一重要算法。 ... [详细]
  • C#编程中按钮控件的使用与优化 ... [详细]
author-avatar
blue暗紫天堂
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有