当前位置: 首页 > news >正文

wix做网站的建议免费正能量erp软件下载

wix做网站的建议,免费正能量erp软件下载,图书购物网站开发总结,电脑做试卷的网站本专栏内容为:C学习专栏,分为初阶和进阶两部分。 通过本专栏的深入学习,你可以了解并掌握C。 💓博主csdn个人主页:小小unicorn ⏩专栏分类:C 🚚代码仓库:小小unicorn的代码仓库&…

本专栏内容为:C++学习专栏,分为初阶和进阶两部分。 通过本专栏的深入学习,你可以了解并掌握C++。

💓博主csdn个人主页:小小unicorn
⏩专栏分类:C++
🚚代码仓库:小小unicorn的代码仓库🚚
🌹🌹🌹关注我带你学习编程知识

类和对象

  • 1.求1+2+3+…+n
  • 2.计算一年的第几天
  • 3.日期差值
  • 4.打印日期
  • 5. 日期累加

1.求1+2+3+…+n

题目来源:求1+2+3+…+n
题目描述:
 求1+2+3+…+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。

示例:
 输入:5
 返回值:15

分析:
 若是只看题目不管要求,这是一道非常简单的题目,我们有好几种方式可以得出最终结果,但加上题目限制条件,可能大多数博友都懵了。
我们来捋一捋:
 1、不能使用乘除法,等差数列求和公式不能用了。
 2、不能使用for、while,循环求解不能用了。
 3、不能使用switch、case和A?B:C,递归求解也不能用了。

思路:
这道题用常规的方式确实解决不了,因为题目把我们要用到的东西都限制死了。解决这道题之前我们需要知道:当一个对象被创建的时候,该对象会自动调用其默认构造函数。
 我们需要计算的是1-n这n个数的和,那么我们可以创建n个类对象,这样就可以调用n次构造函数,这就相当于代替了递归。每次需要被加的数都比上一次被加的数大一,我们可以借助于类的静态成员变量,在构造函数中设置该静态成员变量自增即可实现。特别注意,这里必须是静态成员变量,不能是普通的成员变量,因为每个对象被创建时都有属于自己的普通成员变量,而静态成员变量是属于整个类的,这样才能使得这n次调用构造函数时自增的是同一个变量,每个对象访问到的静态成员变量是同一个。同理,存储累加结果的变量也必须是静态成员变量。

class Add
{
public:Add() //构造函数{_num++;_ret += _num;}static int _num; //静态成员变量,存储正在累加的数字static int _ret; //静态成员变量,存储1+2+3+...+n的结果
};
//静态成员变量的定义
int Add::_num = 0;
int Add::_ret = 0;
class Solution 
{
public:int Sum_Solution(int n) {//多个测试用例,可能会多次调用,做好初始化工作//防止第二个测试用例的结果是在第一个测试用例的基础上继续累加得到的Add::_num = 0;Add::_ret = 0;Add* p = new Add[n]; //为n个Add类对象申请空间(可调用n次构造函数)return Add::_ret; //返回1+2+3+...+n的结果}
};

代码中为了可以通过类名和类的访问限定符直接突破类域,进而访问到静态成员变量,于是把类的成员变量直接设置为了公有(public)。我们知道,将类的成员变量设置为公有是不安全的,对此,我们可以使用友元类来解决该问题。

class Add
{friend class Solution; //声明Solution是Add的有元类
public:Add() //构造函数{_num++;_ret += _num;}
private:static int _num; //静态成员变量,存储正在累加的数字static int _ret; //静态成员变量,存储1+2+3+...+n的结果
};
//静态成员变量的定义
int Add::_num = 0;
int Add::_ret = 0;
class Solution {
public:int Sum_Solution(int n) {//多个测试用例,可能会多次调用,做好初始化工作//防止第二个测试用例的结果是在第一个测试用例的基础上继续累加得到的Add::_num = 0;Add::_ret = 0;Add* p = new Add[n]; //为n个Add类对象申请空间(可调用n次构造函数)return Add::_ret; //返回1+2+3+...+n的结果}
};

代码中我们将Solution声明为Add的友元类,这样Solution类的成员函数就可以访问Add中的非公有成员了。但在某种意义上来说,使用友元是破坏了封装的,使得Solution类的独立性降低了。
 实际上,访问类中的静态成员变量最标准的方法是通过静态成员函数,我们可以通过定义静态成员函数来获取静态成员变量,或是对静态成员变量进行修改。

class Add
{
public:Add() //构造函数{_num++;_ret += _num;}static void Init() //对静态成员变量进行初始化{_num = 0;_ret = 0;}static int Getret() //获取静态成员变量_ret{return _ret;}
private:static int _num; //静态成员变量,存储正在累加的数字static int _ret; //静态成员变量,存储1+2+3+...+n的结果
};
//静态成员变量的定义
int Add::_num = 0;
int Add::_ret = 0;
class Solution 
{
public:int Sum_Solution(int n) {//多个测试用例,可能会多次调用,做好初始化工作//防止第二个测试用例的结果是在第一个测试用例的基础上继续累加得到的Add::Init();//Add arr[n];Add* p = new Add[n]; //为n个Add类对象申请空间(可调用n次构造函数)return Add::Getret(); //返回1+2+3+...+n的结果}
};

2.计算一年的第几天

题目来源:计算日期到天数转换
题目描述:
 根据输入的日期计算是这一年的第几天。

示例:
 输入:2021 7 18
 输出:199

思路:
 计算某日期是该年的第几天,也就是计算从该年的1月1日到该日期一共有多少天。计算总天数时,我们可以先按照平年的天数进行计算,这样一来每个月的天数都是固定的,然后再判断所给日期是否为3月及以上,因为此时才需要考虑是否为闰年,若日期为3月及以上并且为闰年,则将之前得到的总天数+1作为最终的总天数。

#include <iostream>
using namespace std;
int main()
{int year, month, day;cin >> year >> month >> day; //输入日期int daysArray[13] = { 0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334, 365 }; //daysArray[i]表示1月-i月的总天数(默认2月为28天)int totalDay = daysArray[month - 1] + day; //总天数if ((month > 2) && ((year % 4 == 0 && year % 100 != 0) || (year % 400 == 0))) //如果所给日期为3月及以上,并且该年为闰年{totalDay += 1; //总天数+1(2月29日)}cout << totalDay << endl; //输出总天数,即该日期为该年的第几天return 0;
}

实现二:

#include <iostream>using namespace std;
int month[12] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};int main() 
{int y, m, d;cin >> y >> m >> d;//输入年月日int sum = 0;for (int i = 1; i < m; i++) { //加每月的天数sum += month[i - 1];}sum += d; //加日数if (((y % 4 == 0 && y % 100 != 0) || y % 400 == 0) &&m > 2) //闰年并且月份大于2,则加一sum++;cout << sum << endl;return 0;
}

3.日期差值

题目来源:日期差值
题目描述:
 有两个日期,求两个日期之间的天数,如果两个日期是连续的我们规定它们之间的天数为两天。

示例:
 输入:19700101
    20210718
 输出:18827

思路:
 根据所给的两个日期,分别得到两个日期的年、月、日,然后先计算出这两个日期年相差的天数,得到的值减去第一个日期当年的天数,再加上第二个日期当年的天数即可,但是题目规定:如果两个日期是连续的,那么题目之间的天数为两天。这意味着我们需要计算的日期差值为闭区间 [date1, date2],所以输出结果时需要再加上1。

//日期差值
#include <iostream>
using namespace std;
//判断是否为闰年
bool IsLeapYear(int year)
{return ((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0);
}
int main()
{int date1, date2; //存储两个日期int year1, year2, month1, month2, day1, day2; //存储两个日期的年、月、日int ret = 0; //存储两个日期的差值int dayArray[13] = { 0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 }; //dayArray[i]代表i月的天数(平年)while (cin >> date1 >> date2) //多组测试数据{//确保第一个日期比第二个日期小if (date1 > date2){int tmp = date1;date1 = date2;date2 = tmp;}//根据两个日期得到其年、月、日year1 = date1 / 10000, year2 = date2 / 10000;day1 = date1 % 100, day2 = date2 % 100;month1 = date1 % 10000 / 100, month2 = date2 % 10000 / 100;//计算年相差的天数for (int year = year1; year < year2; year++){if (IsLeapYear(year))ret += 366;elseret += 365;}auto getCurYearDays = [&dayArray](int year, int month, int day)->int{int total = 0;for (int i = 1; i < month; i++) {total += dayArray[i];if (i == 2 && IsLeapYear(year))total++;}return total + day;};//减去date1当年的天数int days1 = getCurYearDays(year1, month1, day1);ret -= days1;//加上date2当年的天数int days2 = getCurYearDays(year2, month2, day2);ret += days2;ret++; //结果为闭区间[date1, date2],所以需要再加1cout << ret << endl;}return 0;
}

4.打印日期

题目来源:打印日期
题目描述:
 给出年份m和一年中的第n天,计算出第n天是几月几号。

示例:
 输入:2021 100
 输出:2021-04-10

思路:
 根据得到的年份判断该年是否为闰年,从而得到该年每月的准确天数。设置月份从1月开始,判断所给总天数是否大于该年该月的总天数,若大于,则将总天数减去该月的总天数后作为新的总天数,然后将月份加一,继续进行判断;若小于,则结束判断,输出日期即可。

#include <iostream>
using namespace std;
int main()
{int year, day;int dayArray[13] = { 0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 }; //dayArray[i]代表i月的天数(平年)while (cin >> year >> day) //多组测试数据{int month = 1; //month从1月开始if (((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0)) //判断该年是否为闰年dayArray[2] += 1; //闰年2月为29天//使日期合法while (day > dayArray[month]){day -= dayArray[month];month++;}printf("%d-%02d-%02d\n", year, month, day); //按格式输出}return 0;
}

5. 日期累加

题目来源:日期累加
题目描述:
 设计一共程序能计算一个日期加上若干天后是什么日期。

输入描述:
 输入第一行表示样例个数m,接下来m行每行四个整数分别表示年月日和累加的天数。

输出描述:
 输出m行每行按yyyy-mm-dd的格式输出。

示例:
 输入:2
    2021 7 18 100
    2021 1 1 100
 输出:2021-10-26
    2021-04-11

思路:
 先将需要累加的天数加到“日”上,然后通过不断的迭代使得日期合法,迭代过程如下:判断“日”是否大于该年该月的总天数,若大于,则将“日”减去该月的总天数后作为新的“日”,然后将月份加一,继续进行判断;若小于,则结束判断,输出日期即可。需要注意:每次月份加一后需要判断“年”是否需要进位,若需要进位还需判断进位后的年是否为闰年。

#include <iostream>
using namespace std;
//判断是否为闰年
bool IsLeapYear(int year)
{return ((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0);
}
int main()
{int m, year, month, day, n;int dayArray[13] = { 0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 }; //dayArray[i]代表i月的天数(平年)cin >> m; //读取样例个数for (int i = 0; i < m; i++){cin >> year >> month >> day >> n; //读取年、月、日和需要累加的天数if (IsLeapYear(year))dayArray[2] = 29; //闰年2月设置为29天day += n; //先将需要累加的天数加到“日”上//使日期合法while (day > dayArray[month]){day -= dayArray[month];month++;if (month == 13) //“年”需要进位{year++;month = 1;//判断新的一年是否为闰年if (IsLeapYear(year))dayArray[2] = 29; //闰年2月设置为29天elsedayArray[2] = 28; //平年2月设置为28天}}printf("%d-%02d-%02d\n", year, month, day); //按格式输出}return 0;
}
http://www.hkea.cn/news/30940/

相关文章:

  • 网站系统管理员模块关键词查找工具
  • 望江县建设局网站外贸seo推广招聘
  • 微信网站上传图片手机怎么制作网站
  • 简单做网站需要学什么搜索引擎有哪些网站
  • 网站备案信息加到哪里如何进行网站推广
  • 昭通网站制作aso优化技巧
  • 制作网站时怎样做滚动字幕新网站多久会被百度收录
  • 余姚物流做网站微信指数是搜索量吗
  • 怎样做网站轮播今日国内重大新闻事件
  • 想给大学做网站百度网盘搜索神器
  • jsp网站开发论文官方app下载安装
  • 关于机场建设的网站今日疫情最新情况
  • 网站域名注册服务商google浏览器官方
  • 通过网站开发工具怎么改自动跳网站百度指数有哪些功能
  • 可以发锚文本的网站百度搜索官方网站
  • 东莞网站建设企慕简述如何优化网站的方法
  • 可以做网站的公司seo外包
  • 自己怎么做网站视频赚钱5g网络优化培训
  • 数据库修改网站管理员密码seo网站有优化培训吗
  • 福田做商城网站建设找哪家公司好抖音怎么运营和引流
  • 厘米售卡站怎么做网站禁止搜索引擎收录的方法
  • 网站首页滚动图片怎么做谷歌搜索关键词排名
  • 嵩县网站开发友情链接获取的途径有哪些
  • 国家企业信息公示网(广东)海南快速seo排名优化
  • 高端网站设计 上海徐州seo排名公司
  • 泰安网站建设公司排名石家庄最新消息
  • 域名只做邮箱没网站要备案吗常见的网络推广方式包括
  • 昆山建设局网站360搜索首页
  • 正常做网站多少钱无锡网站制作无锡做网站
  • php做网站csdn网站seo公司哪家好