- 根包含文件——Luaconf.h (src)
LLLLLLLLLLLLLL265161
InsideLualuainteger编译器alignmentc++dll
Luaconf.h是配置的总集,定义了平台相关的设置,是所有文件都包含的,即RootlyIncluded。0.前言开始关注Lua也是06年六月的事情,《程序员》的2006年第六期中,我独独看中了Lua,而不是当时我已经比较熟悉的Python和Ruby,即使它们我都关注了好几年,但是都没有Lua给我的震撼大。于是那个夏天,稍微地尝试读了Lua的代码。开学后,我突然觉得自己有点受唆使,轻信了动态的福音
- C++智能指针编程实例
lixzest
c++开发语言
智能指针是C++11引入的重要特性,用于自动管理动态分配的内存,防止内存泄漏。下面介绍几种高级智能指针编程实例。1.共享所有权模式(shared_ptr)循环引用问题及解决方案#include#includeclassB;//前向声明classA{public:std::shared_ptrb_ptr;~A(){std::couta_ptr;//这里会导致循环引用~B(){std::cout();
- C++039(指针的自增 自减运算)
有点。
C++c++
1.指针的自增自减运算指针变量存储的是地址,因此对指针做运算就等于对地址做运算。下面通过实例介绍指针的自增、自减运算。1.2输出整型变量变化地址定义指针变量和整型变量,并将整型变量的地址赋给指针变量,再进行指针自增、自减运算,输出结果,比较增减前后的数值。代码如下:#includeusingnamespacestd;intmain(){inta=100;int*p=&a;//定义整型指针并赋初值p
- 如何将数的第n位 置0 或者 置1,查询第n位是否为0
盼雨落,等风起
计算机基础C语言技巧c语言数据结构c++开发语言
一先让1向左移n-1位得到a;二如果置1那么就数|a;三如果置0那么就数&(~a)#includeintmain(){inttemp=0xfff3ffff;printf("tempis%x\n",temp);temp=temp|(3<<18);printf("tempis%x\n",temp);temp=temp&(~(3<<18));printf("tempis%x\n",temp);}使用位运
- Android.mk
盼雨落,等风起
安卓脚本文件android
一、基础认知定位AndroidNDK构建系统的GNUMakefile片段,描述NDK项目结构可编译生成:APK、JAVA库、C/C++可执行程序、静态库(.a)、动态库(.so)兼容性:新源码逐渐转向Android.bp,但Android.mk仍被支持文件结构LOCAL_PATH:=$(callmy-dir)#必选:定义当前路径include$(CLEAR_VARS)#必选:清除变量(除LOCAL
- memstr 从内存找字符串
#includechar*memstr(char*full_data,intfull_data_len,char*substr){if(full_data==NULL||full_data_len=sublen);if(memcmp(cur,substr,sublen)==0){//foundreturncur;}}cur++;}returnNULL;}intmain(){chara[26]={'
- c语言 寄存器技巧 (struct 和 union)
盼雨落,等风起
c语言面试c语言c++算法
参考:C语言|位域的使用详解测试代码#includestructpack{unsignedinta:2;//取值范围为:0~3unsignedintb:4;//取值范围为:0~15unsignedintc:6;//取值范围为:0~63};unionu1//u1表示联合体类型名{//unsignedintb;structpackf;unsignedintb;};intmain(void){struc
- linux c的结构体赋值方法
盼雨落,等风起
c语言
主要使用的是第一种,类似数组赋值#includetypedefstructal_data{inta;intb;intc;charch;}al_data;structal_dataad={1,3,9,'A',};structal_dataad2={.a=2,.b=6,.c=18,.ch='B',};structal_dataad3={a:3,b:9,c:27,ch:'C'};intmain(){pr
- 【C#】实现C#传回调函数到C++,由C++计算结果回调返回
加号3
c#c++
1.C++代码实现.h代码extern"C"typedefint(*Callback)(int);extern"C"__declspec(dllexport)voidRegisterCallback(Callbackcb,intx,inty);.cpp代码#include"CallBack.h"voidRegisterCallback(Callbackcb,intx,inty){intresult
- 【设计模式】单例模式之双检锁(Double-Checked Locking)
浩瀚之水_csdn
#软件模式设计模式单例模式
双检锁(Double-CheckedLocking)是一种在多线程环境下高效实现单例模式的技术,它结合了延迟初始化和线程安全的优点,避免了不必要的同步开销。核心思想双检锁的核心思想是:第一重检查(无锁):快速检查实例是否已创建加锁保护:确保只有一个线程进入创建流程第二重检查(有锁):再次检查实例是否已创建创建实例:如果仍未创建,则创建实例经典实现(C++11之前)#includeclassSing
- go vs C#/c/c++
fyifei0558
java开发语言
1.main函数定义Go:funcmain(),不能带参数,也不能有返回值。C/C++:intmain(intargc,char*argv[]),参数可以直接获取命令行参数。C#:staticvoidMain(string[]args),参数直接是命令行参数数组。2.包和导入(import/using/include)Go:用package声明包名,import导入包。没有头文件,所有导出符号靠首
- rknn优化教程(三)
凌佚
rknnCPPxmakeYOLO目标检测c++
文章目录1.前述2.部分代码3.说明1.前述OK,这一篇博客将完整给出最后的优化教程,包括代码设计。首先有这样的目录结构:./rknn_engine├──include│├──def││└──rknn_define.h│└──rknn_engine.h├──src│├──common││├──rknn_data.h││└──rknn_functions.hpp│├──inference││├──i
- 嵌入式开发中.su文件的作用
小米人儿
我的博客嵌入式
reference:https://interrupt.memfault.com/blog/measuring-stack-usagehttps://github.com/ttsiodras/checkStackUsage测试代码#includeintfoo_2(intc){intarray[4];array[1]=c;array[3]=c*c;returnarray[3]-array[1];}i
- 【华为od刷题(C++)】HJ11 数字颠倒
m0_64866459
算法c++开发语言
我的代码:#include#include#include//引入算法库,提供常见的算法,比如排序、查找、反转等,这里使用了reverse函数来反转字符串usingnamespacestd;intmain(){strings;getline(cin,s);reverse(s.begin(),s.end());/*reverse函数反转字符串的字符顺序s.begin()和s.end()分别表示字符串
- 万年历单片机c语言程序,51单片机c语言电子万年历完整程序.pdf
叶居居
万年历单片机c语言程序
该程序为51单片机c语言电子万年历#include"reg52.h"//#include#defineucharunsignedchar#defineuintunsignedintsbitlcden=P3^4;sbitlcdrs=P3^5;sbitDATA=P0^7;sbitRST=P0^5;sbitSCLK=P0^6;sbitmenu=P3^0;//菜单sbitadd=P3^1;//加一sbit
- 【C/C++】数组指针:array 地址 &array *parray 两次解引用 **parray 值相同的原因解析
Herk (ง •̀_•́)ง
C/C++c语言c++数据结构
一、提出问题#includeintmain(){chararray[16]={'A','B'};char(*parray)[16]=&array;printf("========================\n");printf("array:\t%#lx\n",array);printf("&array:\t%#lx\n",&array);printf("&*array:\t%#lx\n",
- CMake指令:find_package
流星雨爱编程
#CMake工具c++开发语言设计模式自动化编译工具CMake跨平台编译
目录1.简介2.搜索模式3.常用参数4.工作流程5.内置模块示例:FindBoost.cmake6.自定义模块文件(Find.cmake)7.模块模式vs配置模式8.总结相关链接1.简介查找模块(findmodule)是一系列用于搜索第三方依赖软件包(包括库或可执行文件)的模块。对查找模块的引用一般不使用include命令,而是使用find_package命令。基本语法find_package([
- 简单的回调函数理解
望外追晚
c++开发语言
使用两个脚本简单理解回调函数。简单来说,将函数B当做另一个函数A的参数进行调用。Demo1使用当前通用的std::function#include//包含std::function和std::bindusingnamespacestd;//普通函数voidmyCallbackFunction(intvalue,stringname){coutcallback,intdata,stringname)
- C++补充知识+专题思维导图
Cyrus_柯
C++c++算法开发语言面向对象
补充知识:1.nullptrNULL在源码中就是一个0,因此可能会出现一些二义性的问题。#includeusingnamespacestd;voidfunc(inta){coutusingnamespacestd;voidfunc(inta){coutusingnamespacestd;intmain(){autoa=10;//a的类型被推导为整型(int)coutusingnamespacest
- 结构体struct 内存分配规则及地址运算3——编译器优化
面包爱阜阳
c++c语言
结构体struct内存优化3——编译器优化#include#include//includinguint32_t...typedefstruct{uint8_tcap_id;//capobjectiduint16_tframe_id;//frameiduint32_tframe_size;//framesizebybyteuint8_tframe[10];//frameuint16_t*p_fra
- 蓝桥杯备考---》模拟算法之扫雷游戏
无敌大饺子 dot
算法蓝桥杯游戏
#includeconstintN=120;usingnamespacestd;intn,m;chara[N][N];intdx[]={-1,-1,0,1,1,1,0,-1};intdy[]={0,1,1,1,0,-1,-1,-1};intmain(){cin>>n>>m;for(inti=1;i>a[i][j];}}for(inti=1;in||y>m){continue;}if(a[x][y]
- webpack < 5 used to include polyfills for node.js core modules by default.
TO_WebNow
Vuejavascriptvue.js
vue-cli5.x版本报错在vue-cli新版本中使用了pdfh5然后报错如下,大致意思是说新版的cli中模块polyfill不会自动引入了Ifyouwanttoincludeapolyfill,youneedto:-addafallback'resolve.fallback:{"https":require.resolve("https-browserify")}'-install'https
- VECTOR 详解
luer9
vector
在c++中,vector是一个十分有用的容器,下面对这个容器做一下总结。1基本操作(1)头文件#include.(2)创建vector对象,vectorvec;(3)尾部插入数字:vec.push_back(a);(4)使用下标访问元素,cout::iteratorit;for(it=vec.begin();it!=vec.end();it++)cout#include#include#inclu
- C语言经典20例(判断闰年)
观音山保我别报错
c语言学习方法
在C语言中,判断一个年份是否为闰年可以通过以下规则来实现:1.如果年份能被4整除且不能被100整除,则是闰年。2.如果年份能被400整除,则也是闰年。以下是具体的C语言代码实现,以及文字讲解:#includeintmain(){intyear;printf("请输入一个年份:");scanf("%d",&year);//判断是否为闰年if((year%4==0&&year%100!=0)||(ye
- 【acwing】数的三次方根
GUO_YYDS
c++算法
数的三次方根给定一个浮点数nnn,求它的三次方根。输入格式共一行,包含一个浮点数nnn。输出格式共一行,包含一个浮点数,表示问题的解。注意,结果保留666位小数。数据范围−10000≤n≤10000-10000\len\le10000−10000≤n≤10000输入样例:1000.00输出样例:10.000000第一种代码#include#includeusingnamespacestd;doub
- 【MySQL】12. C语言与数据库的连接
卡戎-caryon
MySQL数据库mysqlIO笔记c语言
1.下载MySQL的连接库sudoaptinstall-ylibmysqlclient-dev2.MySQL连接库的常用接口介绍通过下面的样例了解MYSQL的常用接口:#include#includeusingnamespacestd;constchar*host="localhost";constchar*user="caryon";constchar*password="20233962Myl
- 统计一个区间内的素数并求和
xtmatao
C语言编程算法c语言
统计一个区间内的素数并求和统计给定整数m和n之间的素数个数以及它们的和并输出#includeintmain(){intm,n;inti;intcnt=0;intsum=0;printf("请输入两个正整数:\n");scanf("%d%d",&m,&n);if(m==1)//排除m等于1是下面的程序会判定1为素数{m=2;}for(i=m;i<=n;i++){intisPrime=1;intk;f
- Linux C语言的opendir如何获取目录下的隐藏文件
华纳云IDC服务商
linux运维服务器
在Linux文件系统中,所谓隐藏文件是文件名以.开头的文件(例如.bashrc、.git、.config等)。在编程层面,opendir+readdir并不会自动排除隐藏文件。只要你不在代码中手动过滤,readdir会把目录下所有文件(包括隐藏文件)都读出来。核心逻辑#include#includeintmain(void){DIR*dir;structdirent*entry;dir=opend
- (C++)vector数组相关基础用法(C++教程)(STL库基础教程)
双叶836
STLC++C++基础教学算法c++c语言数据结构开发语言
源代码:#include#include#includeusingnamespacestd;intmain(){chara;intb;intc;vectornumbers;cout>a;if(a=='#'){break;}numbers.push_back(a);}cout>b;cout>c;if(c>=0&&c#include#includeusingnamespacestd;引入了三个必要的头
- c++ make_unique用法
Coding小公仔
c/c++c++开发语言
std::make_unique使用详解std::make_unique是C++14引入的智能指针工厂函数,用于安全高效地创建std::unique_ptr对象。以下是完整使用指南:1.基本用法#include//创建内置类型autointPtr=std::make_unique(42);//指向int(42)//创建自定义类classMyClass{public:MyClass(inta,dou
- 强大的销售团队背后 竟然是大数据分析的身影
蓝儿唯美
数据分析
Mark Roberge是HubSpot的首席财务官,在招聘销售职位时使用了大量数据分析。但是科技并没有挤走直觉。
大家都知道数理学家实际上已经渗透到了各行各业。这些热衷数据的人们通过处理数据理解商业流程的各个方面,以重组弱点,增强优势。
Mark Roberge是美国HubSpot公司的首席财务官,HubSpot公司在构架集客营销现象方面出过一份力——因此他也是一位数理学家。他使用数据分析
- Haproxy+Keepalived高可用双机单活
bylijinnan
负载均衡keepalivedhaproxy高可用
我们的应用MyApp不支持集群,但要求双机单活(两台机器:master和slave):
1.正常情况下,只有master启动MyApp并提供服务
2.当master发生故障时,slave自动启动本机的MyApp,同时虚拟IP漂移至slave,保持对外提供服务的IP和端口不变
F5据说也能满足上面的需求,但F5的通常用法都是双机双活,单活的话还没研究过
服务器资源
10.7
- eclipse编辑器中文乱码问题解决
0624chenhong
eclipse乱码
使用Eclipse编辑文件经常出现中文乱码或者文件中有中文不能保存的问题,Eclipse提供了灵活的设置文件编码格式的选项,我们可以通过设置编码 格式解决乱码问题。在Eclipse可以从几个层面设置编码格式:Workspace、Project、Content Type、File
本文以Eclipse 3.3(英文)为例加以说明:
1. 设置Workspace的编码格式:
Windows-&g
- 基础篇--resources资源
不懂事的小屁孩
android
最近一直在做java开发,偶尔敲点android代码,突然发现有些基础给忘记了,今天用半天时间温顾一下resources的资源。
String.xml 字符串资源 涉及国际化问题
http://www.2cto.com/kf/201302/190394.html
string-array
- 接上篇补上window平台自动上传证书文件的批处理问卷
酷的飞上天空
window
@echo off
: host=服务器证书域名或ip,需要和部署时服务器的域名或ip一致 ou=公司名称, o=公司名称
set host=localhost
set ou=localhost
set o=localhost
set password=123456
set validity=3650
set salias=s
- 企业物联网大潮涌动:如何做好准备?
蓝儿唯美
企业
物联网的可能性也许是无限的。要找出架构师可以做好准备的领域然后利用日益连接的世界。
尽管物联网(IoT)还很新,企业架构师现在也应该为一个连接更加紧密的未来做好计划,而不是跟上闸门被打开后的集成挑战。“问题不在于物联网正在进入哪些领域,而是哪些地方物联网没有在企业推进,” Gartner研究总监Mike Walker说。
Gartner预测到2020年物联网设备安装量将达260亿,这些设备在全
- spring学习——数据库(mybatis持久化框架配置)
a-john
mybatis
Spring提供了一组数据访问框架,集成了多种数据访问技术。无论是JDBC,iBATIS(mybatis)还是Hibernate,Spring都能够帮助消除持久化代码中单调枯燥的数据访问逻辑。可以依赖Spring来处理底层的数据访问。
mybatis是一种Spring持久化框架,要使用mybatis,就要做好相应的配置:
1,配置数据源。有很多数据源可以选择,如:DBCP,JDBC,aliba
- Java静态代理、动态代理实例
aijuans
Java静态代理
采用Java代理模式,代理类通过调用委托类对象的方法,来提供特定的服务。委托类需要实现一个业务接口,代理类返回委托类的实例接口对象。
按照代理类的创建时期,可以分为:静态代理和动态代理。
所谓静态代理: 指程序员创建好代理类,编译时直接生成代理类的字节码文件。
所谓动态代理: 在程序运行时,通过反射机制动态生成代理类。
一、静态代理类实例:
1、Serivce.ja
- Struts1与Struts2的12点区别
asia007
Struts1与Struts2
1) 在Action实现类方面的对比:Struts 1要求Action类继承一个抽象基类;Struts 1的一个具体问题是使用抽象类编程而不是接口。Struts 2 Action类可以实现一个Action接口,也可以实现其他接口,使可选和定制的服务成为可能。Struts 2提供一个ActionSupport基类去实现常用的接口。即使Action接口不是必须实现的,只有一个包含execute方法的P
- 初学者要多看看帮助文档 不要用js来写Jquery的代码
百合不是茶
jqueryjs
解析json数据的时候需要将解析的数据写到文本框中, 出现了用js来写Jquery代码的问题;
1, JQuery的赋值 有问题
代码如下: data.username 表示的是: 网易
$("#use
- 经理怎么和员工搞好关系和信任
bijian1013
团队项目管理管理
产品经理应该有坚实的专业基础,这里的基础包括产品方向和产品策略的把握,包括设计,也包括对技术的理解和见识,对运营和市场的敏感,以及良好的沟通和协作能力。换言之,既然是产品经理,整个产品的方方面面都应该能摸得出门道。这也不懂那也不懂,如何让人信服?如何让自己懂?就是不断学习,不仅仅从书本中,更从平时和各种角色的沟通
- 如何为rich:tree不同类型节点设置右键菜单
sunjing
contextMenutreeRichfaces
组合使用target和targetSelector就可以啦,如下: <rich:tree id="ruleTree" value="#{treeAction.ruleTree}" var="node" nodeType="#{node.type}"
selectionChangeListener=&qu
- 【Redis二】Redis2.8.17搭建主从复制环境
bit1129
redis
开始使用Redis2.8.17
Redis第一篇在Redis2.4.5上搭建主从复制环境,对它的主从复制的工作机制,真正的惊呆了。不知道Redis2.8.17的主从复制机制是怎样的,Redis到了2.4.5这个版本,主从复制还做成那样,Impossible is nothing! 本篇把主从复制环境再搭一遍看看效果,这次在Unbuntu上用官方支持的版本。 Ubuntu上安装Red
- JSONObject转换JSON--将Date转换为指定格式
白糖_
JSONObject
项目中,经常会用JSONObject插件将JavaBean或List<JavaBean>转换为JSON格式的字符串,而JavaBean的属性有时候会有java.util.Date这个类型的时间对象,这时JSONObject默认会将Date属性转换成这样的格式:
{"nanos":0,"time":-27076233600000,
- JavaScript语言精粹读书笔记
braveCS
JavaScript
【经典用法】:
//①定义新方法
Function .prototype.method=function(name, func){
this.prototype[name]=func;
return this;
}
//②给Object增加一个create方法,这个方法创建一个使用原对
- 编程之美-找符合条件的整数 用字符串来表示大整数避免溢出
bylijinnan
编程之美
import java.util.LinkedList;
public class FindInteger {
/**
* 编程之美 找符合条件的整数 用字符串来表示大整数避免溢出
* 题目:任意给定一个正整数N,求一个最小的正整数M(M>1),使得N*M的十进制表示形式里只含有1和0
*
* 假设当前正在搜索由0,1组成的K位十进制数
- 读书笔记
chengxuyuancsdn
读书笔记
1、Struts访问资源
2、把静态参数传递给一个动作
3、<result>type属性
4、s:iterator、s:if c:forEach
5、StringBuilder和StringBuffer
6、spring配置拦截器
1、访问资源
(1)通过ServletActionContext对象和实现ServletContextAware,ServletReque
- [通讯与电力]光网城市建设的一些问题
comsci
问题
信号防护的问题,前面已经说过了,这里要说光网交换机与市电保障的关系
我们过去用的ADSL线路,因为是电话线,在小区和街道电力中断的情况下,只要在家里用笔记本电脑+蓄电池,连接ADSL,同样可以上网........
 
- oracle 空间RESUMABLE
daizj
oracle空间不足RESUMABLE错误挂起
空间RESUMABLE操作 转
Oracle从9i开始引入这个功能,当出现空间不足等相关的错误时,Oracle可以不是马上返回错误信息,并回滚当前的操作,而是将操作挂起,直到挂起时间超过RESUMABLE TIMEOUT,或者空间不足的错误被解决。
这一篇简单介绍空间RESUMABLE的例子。
第一次碰到这个特性是在一次安装9i数据库的过程中,在利用D
- 重构第一次写的线程池
dieslrae
线程池 python
最近没有什么学习欲望,修改之前的线程池的计划一直搁置,这几天比较闲,还是做了一次重构,由之前的2个类拆分为现在的4个类.
1、首先是工作线程类:TaskThread,此类为一个工作线程,用于完成一个工作任务,提供等待(wait),继续(proceed),绑定任务(bindTask)等方法
#!/usr/bin/env python
# -*- coding:utf8 -*-
- C语言学习六指针
dcj3sjt126com
c
初识指针,简单示例程序:
/*
指针就是地址,地址就是指针
地址就是内存单元的编号
指针变量是存放地址的变量
指针和指针变量是两个不同的概念
但是要注意: 通常我们叙述时会把指针变量简称为指针,实际它们含义并不一样
*/
# include <stdio.h>
int main(void)
{
int * p; // p是变量的名字, int *
- yii2 beforeSave afterSave beforeDelete
dcj3sjt126com
delete
public function afterSave($insert, $changedAttributes)
{
parent::afterSave($insert, $changedAttributes);
if($insert) {
//这里是新增数据
} else {
//这里是更新数据
}
}
 
- timertask
shuizhaosi888
timertask
java.util.Timer timer = new java.util.Timer(true);
// true 说明这个timer以daemon方式运行(优先级低,
// 程序结束timer也自动结束),注意,javax.swing
// 包中也有一个Timer类,如果import中用到swing包,
// 要注意名字的冲突。
TimerTask task = new
- Spring Security(13)——session管理
234390216
sessionSpring Security攻击保护超时
session管理
目录
1.1 检测session超时
1.2 concurrency-control
1.3 session 固定攻击保护
 
- 公司项目NODEJS实践0.3[ mongo / session ...]
逐行分析JS源代码
mongodbsessionnodejs
http://www.upopen.cn
一、前言
书接上回,我们搭建了WEB服务端路由、模板等功能,完成了register 通过ajax与后端的通信,今天主要完成数据与mongodb的存取,实现注册 / 登录 /
- pojo.vo.po.domain区别
LiaoJuncai
javaVOPOJOjavabeandomain
POJO = "Plain Old Java Object",是MartinFowler等发明的一个术语,用来表示普通的Java对象,不是JavaBean, EntityBean 或者 SessionBean。POJO不但当任何特殊的角色,也不实现任何特殊的Java框架的接口如,EJB, JDBC等等。
即POJO是一个简单的普通的Java对象,它包含业务逻辑
- Windows Error Code
OhMyCC
windows
0 操作成功完成.
1 功能错误.
2 系统找不到指定的文件.
3 系统找不到指定的路径.
4 系统无法打开文件.
5 拒绝访问.
6 句柄无效.
7 存储控制块被损坏.
8 存储空间不足, 无法处理此命令.
9 存储控制块地址无效.
10 环境错误.
11 试图加载格式错误的程序.
12 访问码无效.
13 数据无效.
14 存储器不足, 无法完成此操作.
15 系
- 在storm集群环境下发布Topology
roadrunners
集群stormtopologyspoutbolt
storm的topology设计和开发就略过了。本章主要来说说如何在storm的集群环境中,通过storm的管理命令来发布和管理集群中的topology。
1、打包
打包插件是使用maven提供的maven-shade-plugin,详细见maven-shade-plugin。
<plugin>
<groupId>org.apache.maven.
- 为什么不允许代码里出现“魔数”
tomcat_oracle
java
在一个新项目中,我最先做的事情之一,就是建立使用诸如Checkstyle和Findbugs之类工具的准则。目的是制定一些代码规范,以及避免通过静态代码分析就能够检测到的bug。 迟早会有人给出案例说这样太离谱了。其中的一个案例是Checkstyle的魔数检查。它会对任何没有定义常量就使用的数字字面量给出警告,除了-1、0、1和2。 很多开发者在这个检查方面都有问题,这可以从结果
- zoj 3511 Cake Robbery(线段树)
阿尔萨斯
线段树
题目链接:zoj 3511 Cake Robbery
题目大意:就是有一个N边形的蛋糕,切M刀,从中挑选一块边数最多的,保证没有两条边重叠。
解题思路:有多少个顶点即为有多少条边,所以直接按照切刀切掉点的个数排序,然后用线段树维护剩下的还有哪些点。
#include <cstdio>
#include <cstring>
#include <vector&