小技巧(日后遇见进行补充)。。。

2024-04-23 20:58

本文主要是介绍小技巧(日后遇见进行补充)。。。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.对浮点型数据取整:有四舍五入取整,向上取整,和向下取整。代码:用函数需要 cmath 头文件,数据取整在一些数据处理时会有很多的用处。

#include<iostream>
#include<cmath>
using namespace std;
int main()
{double a=2.1;cout<<ceil(a)<<endl;  //向上取整 cout<<floor(a)<<endl;   //向下取整 cout<<round(a)<<endl;  //四舍五入 return 0;
}

2.素数打表技巧:

素数这个很头疼的问题,通常我们 需要打表解决问题。fun函数进行打表,vis 数组下标就是快速判断素数,Prime 数组内部数据就是一个一个的素数,可以快速应用。

#include<iostream>
#include<cmath>
#include<string.h>
using namespace std;
const int maxn=1000005;bool vis[maxn];	 
int Prime[maxn]; 
int cnt;
int n;
void fun()
{cnt = 0;memset(vis,true,sizeof(vis));vis[0] = vis[1] = false;	vis[2] = true;for(int i = 2 ; i<=maxn; i++){if(vis[i]){Prime[cnt++] = i;for(int j = i+i ; j<=maxn; j+=i){vis[j] = false;}}}
}int main()
{fun();return 0;
}

3.年月日模板 月份天数模板:也不能叫板子(自己瞎搞)吧,就是处理起来比较方便而已。


int a[]={0,31,31+29,31+29+31,31+29+31+30,31+29+31+30+31,31+29+31+30+31+30,31+29+31+30+31+30+31,31+29+31+30+31+30+31+31,31+29+31+30+31+30+31+31+30,31+29+31+30+31+30+31+31+30+31,31+29+31+30+31+30+31+31+30+31+30,31+29+31+30+31+30+31+31+30+31+30+31};

4. 大数据年份之间的闰年数量(求解2月29日在两年份之间一共有多少个),如果我们一个年份一个年份遍历,肯定会超时(肯定是不用说的),这就需要我们了解快速求解闰年 数量 的数学方法:

计算到某年为止的闰年数,其实很简单.设要计算的年为A,则到A年为止(含A年)的闰年数为:

闰年数=int(year)/4-int(year)/100+(int)year/400;    这个是到year 年一共的闰年数量,注意注意注意:末尾年year 也是算进去的。有了这个公式,就可以很快计算出到某个年是的闰年数量了。下面看一道题目:

February 29

HihoCoder - 1148

这道题目就是找出2个年数之间的所有的闰年数量,就是用上面这个公式,先算出由起始开始 到A年的闰年数量,然后再算到B年闰年数量,然后再减一下。就是答案。

 

 5.最大公约数GCD 函数递归求法:

int gcd(int x,int y)
{return  y==0?x:gcd(y,x%y);        
}

一行代码搞定求解最大公约数

6.判断是否回文数的求法:

        int num;cin>>num;int c=num;int sum1=0;while(c){sum1=sum1*10+c%10;c=c/10;}if(sum1==num)cout<<"是回文数"<<endl;

7.vector<int>mp  中搜索第一次出现的数据 ,用 find 函数来查

8.用栈来模拟计算器的实现,看一下题目:巧用stack 和 getchar( ),一个用来存储数据,一个用来判断结束,比如说换行和输入0来结束程序的运行。  

读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值。

Input

测试输入包含若干测试用例,每个测试用例占一行,每行不超过200个字符,整数和运算符之间用一个空格分隔。没有非法表达式。当一行中只有0时输入结束,相应的结果不要输出。

Output

对每个测试用例输出1行,即该表达式的值,精确到小数点后2位。

Sample Input

1 + 2
4 + 2 * 5 - 7 / 11
0

Sample Output

3.00
13.36

 还有输入的问题,这是一个中缀表达式的题目,一开始完全没有思路,怎么来判断乘法和加法的优先级呢?难道不断的循环,一直到最后一个数吗?(我想,好麻烦啊,我也不会啊),看了看网上的代码 ,有的很长,有的用的stack 来模拟加法,巧用了getchar ,因为是不定长数据输入,(一开始想用 getline,来实现,但是也是不好实现 ),所以就用getchar 有没有读取换行符 来实现本次输入的结束标志(学到了)。

代码:
 

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<string.h>
#include<vector>
#include<stack>typedef long long ll;
using namespace std;
const int maxn=1e6+7;
const ll inf=(1<<30);
typedef pair<int,int> p;int main()
{double n;while(scanf("%lf",&n)!=EOF){stack<double>s;s.push(n);	char h=getchar();if(s.top()==0&&h=='\n')break;char a;double b;while(scanf("%c %lf",&a,&b)!=EOF){if(a=='+')s.push(b);else if(a=='-')s.push(-b);else if(a=='*'){double temp=s.top();s.pop();s.push(temp*b);}else{double temp=s.top();s.pop();s.push(temp/b);}		a=getchar();if(a=='\n')break;	}double sum=0;while(!s.empty()){sum+=s.top();s.pop();}printf("%.2lf\n",sum);}return 0;
}

用到getchar( ),需要提前将一些其他没有用的字符提前吸收掉(有的题目会有要求限制,比如空格,在输入前,和再一次循环后,也要吸收一下,要注意)。
9.有些问题用c++ 的 STL 处理起来 就很容易,就像很多的容器vector set queue ,一些基础的C++容器 用法就不说了,基本上都是会用的 ,下面我只是记一下不常用的用法(大佬自动忽略 ,小弟好记性不如烂键盘(好贵的) ):

 vector ,这个两个 vector 合并到一个vector 中的操作,我遇到过一次,也是很强大的用法          

int main()
{std::ios::sync_with_stdio(false);vector<int>s1,s2;s1.push_back(6);s1.push_back(1);s1.push_back(9);s2.push_back(2);s2.push_back(1);s2.push_back(5);//s1 输出 for(int i=0;i<s1.size();i++){cout<<s1[i]<<' ';}cout<<endl;//s2 输出 for(int i=0;i<s2.size();i++){cout<<s2[i]<<' ';}cout<<endl;/*如果将s1 变为 s2 ,丢掉s1 原来的数据   方法 1.s1=s2;2.s1.assign(s2.begin(),s2.end());	当然还是 第一种简单  *///将 s2 中的元素都放到了 s1中,不会丢掉原来  s1.insert(s1.end(),s2.begin(),s2.end());for(int i=0;i<s1.size();i++){cout<<s1[i]<<' ';}cout<<endl;return 0;	
}

10.使用数组和结构体来模拟链表实现连起来的操作,比如在一个结构体中,下标来表示当前地址,里面的元素一个是当前数据,和下一个的地址。这样就可以简单的模拟一下链表的实现,地址和下一个地址都被存储起来,(确实很妙的简单模拟链表)  

11.对于一些求后几位的题目,直接每项取余就可以了,要不然数据直接爆炸(long long都会爆的,我怎么那么傻,记得当时跑数据的时候,没有爆啊,也没有出现什么负的数据 ,等异常的现象,看来是当时敲错了,看来做填空题还是要细心的,后头也要检查一遍,哎,可惜)。就是下面这个,可惜,可惜啊。

#include<iostream>
#include<stdio.h>
#include<string>
#include<vector>
#include<algorithm>
#include<string.h>
const int maxn=1005;
typedef long long ll;
using namespace std;
const int inf=1e8;
int a[30000000];
int main()
{  a[1]=1;a[2]=1;a[3]=1;for(int i=4;i<=20190324;i++)a[i]=(a[i-1]+a[i-2]+a[i-3])%10000;cout<<a[20190324]<<endl;return 0;
}

    还有一个非常重要的事情就是,不管在hdu 和poj 里面,一定不能将 strlen(字符数组) 放在 for循环当中,都会超时的,已经深受其害了,以后做题,一定不能将strlen( )函数放在for 循环当中,会导致超时,所以一定不要,一定不要,一定不要。

 

memset() 初始化数组只能初始化为0,不能初始化为其他的指定数值,如果需要的话,用循环来赋值,或者使用  fill来初始化 ****,这个很重要,能WA到死。

对于一个数组来说,我们按照sort来自定义排序,我们还要自己写一个cmp函数,现在我们可以直接写出一个语句,直接表达出相同的意思,就是下面这个代码:


#include<iostream>
#include<algorithm>
using namespace std;
#include<map>
#include<string>
#include<sstream>
typedef long long ll;
typedef pair<char, int> p;
const int maxn = 100005;int main()
{int a[10]={1,5,9,4,5,2,6,9,7,9};sort(a,a+10,greater<int>());for(int i=0;i<10;i++)cout<<a[i]<<' ';cout<<endl;	sort(a,a+10,less<int>());for(int i=0;i<10;i++)cout<<a[i]<<' ';	return 0;
}

 

这篇关于小技巧(日后遇见进行补充)。。。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/929866

相关文章

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

购买磨轮平衡机时应该注意什么问题和技巧

在购买磨轮平衡机时,您应该注意以下几个关键点: 平衡精度 平衡精度是衡量平衡机性能的核心指标,直接影响到不平衡量的检测与校准的准确性,从而决定磨轮的振动和噪声水平。高精度的平衡机能显著减少振动和噪声,提高磨削加工的精度。 转速范围 宽广的转速范围意味着平衡机能够处理更多种类的磨轮,适应不同的工作条件和规格要求。 振动监测能力 振动监测能力是评估平衡机性能的重要因素。通过传感器实时监

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

滚雪球学Java(87):Java事务处理:JDBC的ACID属性与实战技巧!真有两下子!

咦咦咦,各位小可爱,我是你们的好伙伴——bug菌,今天又来给大家普及Java SE啦,别躲起来啊,听我讲干货还不快点赞,赞多了我就有动力讲得更嗨啦!所以呀,养成先点赞后阅读的好习惯,别被干货淹没了哦~ 🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,助你一臂之力,带你早日登顶🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!! 环境说明:Windows 10

遮罩,在指定元素上进行遮罩

废话不多说,直接上代码: ps:依赖 jquer.js 1.首先,定义一个 Overlay.js  代码如下: /*遮罩 Overlay js 对象*/function Overlay(options){//{targetId:'',viewHtml:'',viewWidth:'',viewHeight:''}try{this.state=false;//遮罩状态 true 激活,f

利用matlab bar函数绘制较为复杂的柱状图,并在图中进行适当标注

示例代码和结果如下:小疑问:如何自动选择合适的坐标位置对柱状图的数值大小进行标注?😂 clear; close all;x = 1:3;aa=[28.6321521955954 26.2453660695847 21.69102348512086.93747104431360 6.25442246899816 3.342835958564245.51365061796319 4.87

小技巧绕过Sina Visitor System(新浪访客系统)

0x00 前言 一直以来,爬虫与反爬虫技术都时刻进行着博弈,而新浪微博作为一个数据大户更是在反爬虫上不遗余力。常规手段如验证码、封IP等等相信很多人都见识过…… 当然确实有需要的话可以通过新浪开放平台提供的API进行数据采集,但是普通开发者的权限比较低,限制也比较多。所以如果只是做一些简单的功能还是爬虫比较方便~ 应该是今年的早些时候,新浪引入了一个Sina Visitor Syst

【多系统萎缩患者必看】✨维生素补充全攻略,守护你的健康每一天!

亲爱的朋友们,今天我们要聊一个既重要又容易被忽视的话题——‌多系统萎缩患者如何科学补充维生素‌!🌟 在这个快节奏的生活中,健康成为了我们最宝贵的财富,而对于多系统萎缩(MSA)的患者来说,合理的营养补充更是维护身体机能、提升生活质量的关键一步。👇 🌈 为什么多系统萎缩患者需要特别关注维生素? 多系统萎缩是一种罕见且复杂的神经系统疾病,它影响身体的多个系统,包括自主神经、锥体外系、小脑及锥

Python脚本:对文件进行批量重命名

字符替换:批量对文件名中指定字符进行替换添加前缀:批量向原文件名添加前缀添加后缀:批量向原文件名添加后缀 import osdef Rename_CharReplace():#对文件名中某字符进行替换(已完结)re_dir = os.getcwd()re_list = os.listdir(re_dir)original_char = input('请输入你要替换的字符:')replace_ch