【C++类和对象】日期类的实现

💞💞 前言

hello hello~ ,这里是大耳朵土土垚~💖💖 ,欢迎大家点赞🥳🥳关注💥💥收藏🌹🌹🌹
在这里插入图片描述

💥个人主页:大耳朵土土垚的博客
💥 所属专栏:C++入门至进阶
这里将会不定期更新有关C++的内容,希望大家多多点赞关注收藏💖💖

目录

  • 💞💞 前言
  • 1.日期类Date的构造
  • 2.日期类Date的实现
    • 2.1获取某年某月的天数
    • 2.2默认成员函数的实现
      • 2.2.1全缺省的构造函数
      • 2.2.2拷贝构造函数
      • 2.2.3赋值运算符重载
      • 2.2.4析构函数
    • 2.3日期计算类函数
      • 2.3.1日期+=天数
      • 2.3.2日期+天数
      • 2.3.3日期-=天数
      • 2.3.4日期-天数
      • 2.3.5日期-日期 返回天数
    • 2.4运算符重载类函数
      • 2.4.1 >运算符重载
      • 2.4.2 ==运算符重载
      • 2.4.3 >=运算符重载
      • 2.4.4 <运算符重载
      • 2.4.5 <=运算符重载
      • 2.4.6 !=运算符重载
      • 2.4.7 前置++与后置++
      • 2.4.8 前置--与后置--
  • 3.完整代码+运行结果
  • 4.结语

通过下面的学习我们将构建简单日期计算器的各种功能实现:
在这里插入图片描述

1.日期类Date的构造

这里的函数大多在日期类中声明,定义在类外部实现

#include<iostream>
using namespace std;
class Date
{
public:// 获取某年某月的天数inline int GetMonthDay(int year, int month){int montharray[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };//如果是二月就需要判断是不是闰年if (month == 2 &&(((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0))){return 29;}return montharray[month];//月份天数数组设置为13,方便直接按月份返回}// 全缺省的构造函数Date(int year = 1900, int month = 1, int day = 1);// 拷贝构造函数// d2(d1)Date(const Date& d);// 赋值运算符重载// d2 = d3 -> d2.operator=(&d2, d3)Date& operator=(const Date& d){if (*this != d){_year = d._year;_month = d._month;_day = d._day;return *this;}}// 析构函数~Date();//打印日期void Print(){cout << _year << "/" << _month << "/" << _day << endl;}// 日期+=天数Date& operator+=(int day);// 日期+天数Date operator+(int day);// 日期-天数Date operator-(int day);// 日期-=天数Date& operator-=(int day);// 前置++Date& operator++();// 后置++Date operator++(int);// 后置--Date operator--(int);// 前置--Date& operator--();// >运算符重载bool operator>(const Date& d);// ==运算符重载bool operator==(const Date& d);// >=运算符重载bool operator >= (const Date& d);// <运算符重载bool operator < (const Date& d);// <=运算符重载bool operator <= (const Date& d);// !=运算符重载bool operator != (const Date& d);// 日期-日期 返回天数int operator-(const Date& d);private:int _year;int _month;int _day;};

日期Date类主要分为成员函数与成员变量两个模块,
成员变量就是上面的 int _year; int _month;int _day;是私有(private)的,这样做的目的是不想让别人得到自己的数据;
成员函数可以分为三类:

  1. 默认成员函数
  2. 日期计算类函数
  3. 运算符重载函数

成员函数是公有的(public),也就是说我们在类的外部也可访问和使用;下面我们将实现这些函数。

2.日期类Date的实现

2.1获取某年某月的天数

// 获取某年某月的天数
inline int GetMonthDay(int year, int month)
{int montharray[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };//如果是二月就需要判断是不是闰年if (month == 2 &&(((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0))){return 29;}return montharray[month];//月份天数数组设置为13,方便直接按月份返回
}

这个函数对于我们后面完整实现日期类有着重要的作用,很多情况下都需要调用它,所以我们在最开始实现并将它设置成内联函数,以提高效率;
此外内联函数声明和定义最好不要分离,否则会出现链接错误,所以这里我们直接在类里面定义;

2.2默认成员函数的实现

2.2.1全缺省的构造函数


// 全缺省的构造函数
Date:: Date(int year, int month, int day)
{_year = year;_month = month;_day = day;//这里可以判断日期是否合理if (month >= 13 && day > GetMonthDay(year, month)){cout << "日期非法输入" << endl;}
}

注意这里在声明的时候给缺省值,定义的时候不写;全缺省的构造函数除了赋值外,如果用户输入13月或者2月31天等不正确的日期,我们还可以在函数内部判断日期是否非法;

2.2.2拷贝构造函数

// 拷贝构造函数
// d2(d1)
Date:: Date(const Date& d)
{_year = d._year;_month = d._month;_day = d._day;
}

2.2.3赋值运算符重载

	// 赋值运算符重载// d2 = d3 -> d2.operator=(&d2, d3)Date& operator=(const Date& d){if (*this != d){_year = d._year;_month = d._month;_day = d._day;return *this;}}

赋值运算符重载如果在类中不显式实现,编译器会生成一个默认的。此时用户再在类外自己实现一个全局的赋值运算符重载,就和编译器在类中生成的默认赋值运算符重载冲突了,故赋值运算符重载只能是类的成员函数。所以我们在类里面声明和定义一起;

2.2.4析构函数

//析构函数
Date::~Date()
{_year = 0;_month = 0;_day = 0;
}

对于没有申请资源的类比如日期类,析构函数可以不写直接使用系统默认生成的就行;

2.3日期计算类函数

2.3.1日期+=天数

// 日期+=天数
Date& Date::operator+=(int day)
{_day += day;while (_day > GetMonthDay(_year, _month)){_day -= GetMonthDay(_year, _month);_month++;if (_month >= 13){_year++;_month = 1;}}return *this;
}

这里采用日满了月就+1,月满了年就+1的方式,此外还要注意每个月的天数都不同,2月不同年份天数也不同分为平年和润年,这就需要使用我们之前实现过的获取某年某月天数的函数了;和日期+天数不同的是,日期+=天数,自己原来的日期会变成+了天数之后的,而日期+天数原来的日期不变, 例如:
在这里插入图片描述d1+=100之后,d1也变了;
这里介绍另一个成员函数Print();
void Print() { cout << _year << "/" << _month << "/" << _day << endl; } 用来打印日期,包含在类里面;

2.3.2日期+天数

// 写法1:日期+天数
Date Date::operator+(int day)
{Date tmp = *this;tmp += day;//利用之前实现过的+=实现return tmp;
}
//写法2:日期+天数
Date Date::operator+(int day)
{
Date tmp = *this;
tmp._day += day;
while (tmp._day > GetMonthDay(tmp._year, tmp._month))
{tmp._day -= GetMonthDay(tmp._year, tmp._month);tmp._month++;if (tmp._month >= 13){tmp._year++;tmp._month = 1;}}
return tmp;
}

因为日期+天数,原来的日期是不变的,所以我们需要创建一个临时变量来存放+天数之后的日期并返回;这里有两种写法,一种对之前实现的+=直接使用,另一种就是再自己写一遍+的代码(和+=类似);

2.3.3日期-=天数

// 日期-=天数
Date& Date::operator-=(int day)
{_day -= day;while (_day < 0){_month--;if (_month == 0){_year--;_month = 12;}_day += GetMonthDay(_year, _month);}return *this;
}

2.3.4日期-天数

// 日期-天数
Date Date::operator-(int day)
{Date tmp = *this;/*tmp._day -= day;while (tmp._day < 0){tmp._month--;if (tmp._month == 0){tmp._year--;tmp._month = 12;}tmp._day += GetMonthDay(tmp._year, tmp._month);}*/tmp -= day;return tmp;
}

2.3.5日期-日期 返回天数

// 日期-日期 返回天数
int Date::operator-(const Date& d)
{//先找较大的日期Date max = *this;Date min = d;//如果*this的日期比d大的话就正常计数int flag = 1;//如果*this的日期比d小的话就先正常计数之后再*(-1)即可,-1用flag来标识if (*this < d){min = *this;max = d;flag = -1;}int CountDay = 0;while (min < max){++min;CountDay++;}return flag * CountDay;
}

这里注意如果日期1-日期2<0;就要返回负数,反之返回正数;
所以我们使用flag来标识;
此外计算两个日期相差的天数可以直接++日期并利用CountDay来记录++了多少次,直到两个日期相等时,CountDay的值就是两个日期的差值,类似于追及问题;
当然也有别的方法来实现这里就写了这一种

2.4运算符重载类函数

2.4.1 >运算符重载

// >运算符重载
bool Date::operator>(const Date& d)
{//先比较年if (_year > d._year)return true;//比较月if (_year == d._year && _month > d._month)return true;//比较天if ((_year == d._year) && (_month == d._month) && (_day > d._day))return true;return false;}

2.4.2 ==运算符重载

// ==运算符重载
bool Date::operator==(const Date& d)
{if ((_year == d._year) && (_month == d._month) && (_day == d._day))return true;return false;
}

2.4.3 >=运算符重载

// >=运算符重载
bool Date::operator >= (const Date& d)
{if (*this > d || *this == d)return true;return false;
}

只需写了 > 和 == 或者 < 和 == 这两个运算符,后面的运算符重载就可以借助这两个运算符直接实现;

2.4.4 <运算符重载

// <运算符重载
bool Date::operator < (const Date& d)
{return !(*this >= d);
}

2.4.5 <=运算符重载

// <=运算符重载
bool Date::operator <= (const Date& d)
{return !(*this > d);
}

2.4.6 !=运算符重载

// !=运算符重载
bool Date::operator != (const Date& d)
{return !(*this == d);
}

2.4.7 前置++与后置++

  • 前置++

返回++之后的值

// 前置++
Date& Date::operator++()
{/*_day++;if (_day > GetMonthDay(_year, _month)){_month++;if (_month >= 13){_year++;}}*/*this += 1;return *this;
}

可以直接写,也可以利用前面实现的+=来实现

  • 后置++

返回++之前的值

// 后置++
Date Date::operator++(int)
{Date tmp = *this;/*_day++;if (_day > GetMonthDay(_year, _month)){_month++;if (_month >= 13){_year++;}}*/*this += 1;return tmp;
}

这里因为是返回++之前的值,所以需要创建一个临时变量来存储++之前的日期并返回

2.4.8 前置–与后置–

  • 前置–
// 前置--
Date& Date::operator--()
{return *this -= 1;
}
  • 后置–
// 后置--
Date Date:: operator--(int)
{Date tmp = *this;*this -= 1;return tmp;
}

3.完整代码+运行结果

  • date.h
#pragma once
#include<iostream>
using namespace std;
class Date
{friend ostream& operator<<(ostream& out, const Date& d);friend istream& operator>>(istream& in, Date& d);public:// 获取某年某月的天数inline int GetMonthDay(int year, int month){int montharray[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };//如果是二月就需要判断是不是闰年if (month == 2 && (((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0))){return 29;}return montharray[month];}// 全缺省的构造函数Date(int year = 1900, int month = 1, int day = 1);// 拷贝构造函数// d2(d1)Date(const Date& d);// 赋值运算符重载// d2 = d3 -> d2.operator=(&d2, d3)Date& operator=(const Date& d){if (*this != d){_year = d._year;_month = d._month;_day = d._day;return *this;}}// 析构函数~Date();// 日期+=天数Date& operator+=(int day);// 日期+天数Date operator+(int day);// 日期-天数Date operator-(int day);// 日期-=天数Date& operator-=(int day);// 前置++Date& operator++();// 后置++Date operator++(int);// 后置--Date operator--(int);// 前置--Date& operator--();// >运算符重载bool operator>(const Date& d);// ==运算符重载bool operator==(const Date& d);// >=运算符重载bool operator >= (const Date& d);// <运算符重载bool operator < (const Date& d);// <=运算符重载bool operator <= (const Date& d);// !=运算符重载bool operator != (const Date& d);// 日期-日期 返回天数int operator-(const Date& d);void Print(){cout << _year << "/" << _month << "/" << _day << endl;}private:int _year;int _month;int _day;};
  • date.cpp
 #define _CRT_SECURE_NO_WARNINGS 1
#include"date.h"// 全缺省的构造函数
Date::Date(int year, int month, int day)
{_year = year;_month = month;_day = day;//这里可以判断日期是否合理if (month >= 13 && day > GetMonthDay(year, month)){cout << "日期非法输入" << endl;}
}// 拷贝构造函数// d2(d1)
Date::Date(const Date& d)
{_year = d._year;_month = d._month;_day = d._day;
}// 日期+=天数
Date& Date::operator+=(int day)
{_day += day;while (_day > GetMonthDay(_year, _month)){_day -= GetMonthDay(_year, _month);_month++;if (_month >= 13){_year++;_month = 1;}}return *this;
}// 日期+天数
Date Date::operator+(int day)
{Date tmp = *this;//tmp._day += day;//while (tmp._day > GetMonthDay(tmp._year, tmp._month))//{// tmp._day -= GetMonthDay(tmp._year, tmp._month);//	tmp._month++;//	if (tmp._month >= 13)//	{//		tmp._year++;//		tmp._month = 1;//	}//	//}tmp += day;return tmp;
}// 日期-=天数
Date& Date::operator-=(int day)
{_day -= day;while (_day < 0){_month--;if (_month == 0){_year--;_month = 12;}_day += GetMonthDay(_year, _month);}return *this;
}// 日期-天数
Date Date::operator-(int day)
{Date tmp = *this;/*tmp._day -= day;while (tmp._day < 0){tmp._month--;if (tmp._month == 0){tmp._year--;tmp._month = 12;}tmp._day += GetMonthDay(tmp._year, tmp._month);}*/tmp -= day;return tmp;
}// 前置++
Date& Date::operator++()
{/*_day++;if (_day > GetMonthDay(_year, _month)){_month++;if (_month >= 13){_year++;}}*/*this += 1;return *this;
}// 后置++
Date Date::operator++(int)
{Date tmp = *this;/*_day++;if (_day > GetMonthDay(_year, _month)){_month++;if (_month >= 13){_year++;}}*/*this += 1;return tmp;
}// 后置--
Date Date:: operator--(int)
{Date tmp = *this;*this -= 1;return tmp;
}// 前置--
Date& Date::operator--()
{return *this -= 1;
}// >运算符重载
bool Date::operator>(const Date& d)
{//先比较年if (_year > d._year)return true;//比较月if (_year == d._year && _month > d._month)return true;//比较天if ((_year == d._year) && (_month == d._month) && (_day > d._day))return true;return false;}// ==运算符重载
bool Date::operator==(const Date& d)
{if ((_year == d._year) && (_month == d._month) && (_day == d._day))return true;return false;
}// >=运算符重载
bool Date::operator >= (const Date& d)
{if (*this > d || *this == d)return true;return false;
}// <运算符重载
bool Date::operator < (const Date& d)
{return !(*this >= d);
}// <=运算符重载
bool Date::operator <= (const Date& d)
{return !(*this > d);
}// !=运算符重载
bool Date::operator != (const Date& d)
{return !(*this == d);
}// 日期-日期 返回天数
int Date::operator-(const Date& d)
{//先找较大的日期Date max = *this;Date min = d;//如果*this的日期比d大的话就正常计数int flag = 1;//如果*this的日期比d小的话就先正常计数之后再*(-1)即可,-1用flag来标识if (*this < d){min = *this;max = d;flag = -1;}int CountDay = 0;while (min < max){++min;CountDay++;}return flag * CountDay;
}//析构函数
Date::~Date()
{_year = 0;_month = 0;_day = 0;
}//	//流输出
//ostream operator<<(ostream& out, const Date d)
//{
//	out << d._year << "/" << d._month << "/" << d._day << endl;
//	return out;
//}
//
//
流插入
//istream operator>>(istream& in, const Date d)
//{
//	in >> d._year;
//}//流插入
ostream& operator<<(ostream& out, const Date& d)
{out << d._year << "/" << d._month << "/" << d._day << endl;return out;
}//流提取
istream& operator>>(istream& in, Date& d)
{in >> d._year >> d._month >> d._day;return in;
}
  • test.cpp
int main()
{Date d1(2024, 4, 20);cout << "Today is " << endl;d1.Print();cout << "往后100天是:" << endl;Date(d1 + 100).Print();cout << "往前100天是:" << endl;Date(d1 - 100).Print();cout << "今天与2004年12月14日相差:" << endl;int day = d1 - Date(2004, 12, 14);cout << day << endl;return 0;
}

结果如下:

在这里插入图片描述

4.结语

以上只是一个简单的日期类示例,实际的日期类可能还包括其他功能,例如日期的格式化等操作。这里只是提供了一个起点,大家可以根据自己的需求对日期类进行扩展。以上就是简单日期类的所有内容啦 ~ 完结撒花 ~🥳🎉🎉

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/2978983.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

万兆以太网MAC设计(6)IP协议报文格式详解以及IP层模块设计

文章目录 前言&#xff1a;IPv4报文协议格式二、IP_RX模块设计2.1、模块接口2.2、模块工作过程 三、IP_TX模块设计3.1、模块接口3.2、模块工作过程 四、仿真4.1、发送端4.2、接受端 前言&#xff1a;IPv4报文协议格式 参考&#xff1a;https://sunyunqiang.com/blog/ipv4_prot…

【Linux学习】初始冯诺漫体系结构

文章目录 认识冯诺依曼系统 认识冯诺依曼系统 什么是冯诺依曼体系结构&#xff1f; 冯诺依曼体系结构是一种将程序指令和数据以二进制形式存放在主存储器中&#xff0c;由中央处理器统一控制和执行的计算机系统结构。冯诺依曼体系结构实现了程序的可编程性和硬件与软件的分离&…

jdk版本冲突,java.lang.UnsupportedClassVersionError: JVMCFRE003

主要是编辑器所用的jdk版本和项目用的不一致导致的&#xff0c;虽然编译通过了&#xff0c;但是运行是会报错 选好后点击Apply点击ok&#xff0c;然后重新编译一遍项目就可以了

OpenTelemetry-1.介绍

目录 1.是什么 2.为什么使用 OpenTelemetry 3.数据类型 Tracing Metrics Logging Baggage 4.架构图 5.核心概念 6.相关开源项目 ​编辑 7.分布式追踪的起源 8.百花齐放的分布式追踪 Zipkin Skywalking Pinpoint Jaeger OpenCensus OpenTracing 9.Openteleme…

Linux运维之道:深入探索开源世界的基石

&#x1f482; 个人网站:【 摸鱼游戏】【神级代码资源网站】【工具大全】&#x1f91f; 一站式轻松构建小程序、Web网站、移动应用&#xff1a;&#x1f449;注册地址&#x1f91f; 基于Web端打造的&#xff1a;&#x1f449;轻量化工具创作平台&#x1f485; 想寻找共同学习交…

【LeetCode热题100】【多维动态规划】最小路径和

题目链接&#xff1a;64. 最小路径和 - 力扣&#xff08;LeetCode&#xff09; 给定一个包含非负整数的 m x n 网格 grid &#xff0c;请找出一条从左上角到右下角的路径&#xff0c;使得路径上的数字总和为最小。 说明&#xff1a;每次只能向下或者向右移动一步。 经典动态规…

向量的点积和叉积的几何意义

1. 点积 点积(dot product)&#xff0c;又称标量积&#xff08;scalar product&#xff09;。结果等于。 可用于 判断的是否垂直求投影长度求向量是抑制作用还是促进作用计算两个向量的夹角 2. 叉积 叉积(cross product)&#xff0c;又称为向量积(vector product)。模长等…

vue 表格获取当前行索引,加颜色

vue 表格获取当前行索引&#xff0c;加颜色 <span styledisplay:inline-block;width:10px;height:10px;border-radius:50% :style"{background:color[scope.$index]}" />//定义颜色color: [#5387F7, #A794E0, #F3543C, #999999, #77D3F8, #FFA1B4, #26CEBA, #…

C++:基础语法

一、命名空间 在C/C中&#xff0c;变量、函数和后面要学到的类都是大量存在的&#xff0c;这些变量、函数和类的名称将都存在于全局作用域中&#xff0c;可能会导致很多冲突。使用命名空间的目的是对标识符的名称进行本地化&#xff0c; 以避免命名冲突或名字污染&#xff0c;n…

30V-STM32设计项目

30V-STM32设计 一、项目描述 (已验证) 基于STM32c8t6芯片设计的开发板&#xff0c;支持4-30V宽电压输入&#xff0c;串口模式自动下载功能&#xff0c;支持串口和STlink&#xff0c;方式下载程序 二、原理图介绍 电源电路采用了DCDCLDO电路&#xff0c;如果是外接DC头供电的话&…

BM25检索算法 python

1.简介 BM25&#xff08;Best Matching 25&#xff09;是一种经典的信息检索算法&#xff0c;是基于 TF-IDF算法的改进版本&#xff0c;旨在解决、TF-IDF算法的一些不足之处。其被广泛应用于信息检索领域的排名函数&#xff0c;用于估计文档D与用户查询Q之间的相关性。它是一种…

HarmonyOS开发实例:【图片编辑应用】

介绍 本篇Codelab通过动态设置元素样式的方式&#xff0c;实现几种常见的图片操作&#xff0c;包括裁剪、旋转、缩放和镜像。效果如图所示&#xff1a; 相关概念 [image组件]&#xff1a;图片组件&#xff0c;用来渲染展示图片。[div组件]&#xff1a;基础容器组件&#xff0…

学习Rust的第16天:泛型类型

泛型类型是减少代码重复的好方法&#xff0c;因此它们对性能有巨大的影响&#xff0c;通过利用Rust中的泛型类型&#xff0c;开发人员可以编写更通用和可重用的代码&#xff0c;同时保持类型安全和性能。这种方法不仅减少了冗余&#xff0c;还增强了代码的可维护性和可扩展性&a…

AI大模型探索之路-实战篇2:基于CVP架构-企业级知识库实战落地

目录 前言 一、概述 二、本地知识库需求分析 1. 知识库场景分析 2. 知识库应用特点 3. 知识库核心功能 三、本地知识库架构设计 1. RAG架构分析 2. 大模型方案选型 3. 应用技术架构选型 4. 向量数据库选型 5. 模型选型 三、本地知识库RAG评估 四、本地知识库代码落地 1. 文件…

服务器基础知识(1)

&#x1f40c;博主主页&#xff1a;&#x1f40c;​倔强的大蜗牛&#x1f40c;​ &#x1f4da;专栏分类&#xff1a;服务器❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ 1、什么是服务器 服务器是计算机的一种&#xff0c;它比普通计算机运行更快、负载更高、价格更贵。服务…

WIFI/BT中蓝牙的硬件资源是如何调度的 UART和PCM接口传输的是什么信号

安卓或IOS手机中&#xff0c;wifi/bt中的蓝牙是如何调度硬件资源的&#xff0c;尤其是UART和PCM是如何分配的。M.2 wifi/bt模块或其他形式的模块中&#xff0c;蓝牙是如何调度硬件资源的&#xff0c;尤其是UART和PCM是如何分配的。今天我们就图文并茂的解决这个问题。 蓝牙文件…

MATLAB使用速成 第三章(MATLAB绘图)

一、二维平面作图 1、简单的x-y坐标图 x、y是长度相同的向量&#xff0c;以x的分量为横坐标&#xff0c;y的分量为纵坐标&#xff0c;作平面曲线&#xff0c;使用命令plot(x,y)。&#xff08;可以省略参数x&#xff0c;这样将会以y的分量下标为横坐标&#xff0c;y的分量为纵坐…

如何在极狐GitLab 中用 docker in docker 的方式使用 docker?

GitLab 是一个全球知名的一体化 DevOps 平台&#xff0c;很多人都通过私有化部署 GitLab 来进行源代码托管。极狐GitLab &#xff1a;https://gitlab.cn/install?channelcontent&utm_sourcecsdn 是 GitLab 在中国的发行版&#xff0c;专门为中国程序员服务。可以一键式部署…

C语言游戏实现——贪吃蛇

思路讲解 ** 贪吃蛇游戏是要求我们要操控一条蛇&#xff0c;在游戏规定的空间之内&#xff0c;进行吃食物&#xff0c;吃到一个就增加蛇身的长度&#xff0c;并且游戏得分加1&#xff0c;如果吃到自己&#xff0c;和碰到墙就算死亡&#xff0c;同时可以增加蛇的速度和减慢蛇的…

Python开源项目周排行 2024年第8周

#2024年第8周2024年4月12日1llama3当知无愧AI LLM领域当红炸子鸡&#xff01;Llama 3 是由 Meta AI 开发的大型语言模型 (LLM)&#xff0c;于 2024 年 4 月发布。它基于 Megatron-Turing NLG 模型架构&#xff0c;并在超过 15 万亿个标记的公开可用数据上进行了预训练&#xff…