- 博客(77)
- 收藏
- 关注
原创 NX二次开发—批量导出点工具
设置当勾选显示在信息窗口时,下面的文件成灰色,勾选输出到本地文件时,下面的文件亮起,在update_cb(NXOpen::BlockStyler::UIBlock* block)和dialogShown_cb()添加。创建一个组,添加枚举,设置标题和枚举内容,不显示枚举标题LabelVisibility设置为false,更改枚举风格PresentationStyle设置为Radio Box。添加组,添加特殊里的选择浏览选择文件,设置标题,设置保存文件的类型。添加选择对象,修改标题,设置为多选。
2024-09-12 16:34:42
860
原创 NX二次开发—柱面中心线工具
设置延长线,判断延长线是否勾上,如果延长线没有勾上不显示距离,如果勾上显示距离,在update_cb(NXOpen::BlockStyler::UIBlock* block)和dialogShown_cb()添加。设计一个柱面中心线工具,可以实现选择对象,画出圆柱的中心线,可以更改中心的线的颜色、线型、线宽和图层,是否延长,是否关联。添加切换开关和表达式,设置标题,表示式的单位Dimensionality为长度,值为TRUE。画中心线的思路:找到顶面和底面,然后找到两个圆的圆心,进行连线,在进行其它操作。
2024-09-12 11:40:51
636
原创 NX二次开发—随机分配颜色工具
打开块UI样式编辑器,文件->所有应用模块->开发人员添加枚举,设置对话框的标题为随机颜色,添加提示选择实体或者组件随机分配颜色设置组的标题和枚举,枚举的名称不显示,设置枚举的内容设置枚举样式为Radio Box,根据自己的喜欢添加组和选择对象,设置组的标题为选择,对象为多选代码生成选择C++,保存生成三个文件。
2024-09-11 11:31:15
831
原创 NX—UI界面生成的文件在VS上的设置
D:\NXOPEN下有两个文件夹,application主要存放dlx文件和VS生成的解决方案dll文件;修改VS的输出路径,项目右键选择属性,链接器中的常规,文件路径D:\NXOPEN\application是我自己设置的NX路径,在后面我会写怎么设置的。打开VS创建项目,删除自动生成的cpp文件,将生成的hpp和cpp文件拷贝到项目的目录下,并且在VS项目中添加现有项目。在D:\NXOPEN\startup的menu.men文本添加界面的名称。在此电脑找到属性->高级系统设置->环境变量。
2024-09-11 09:19:58
414
原创 NX二次开发—实体名称工具
打开UI设计界面,文件->所有应用模块->开发人员->块UI编辑器1.选择体收集器设置标题名称和提示信息设置组信息设置选择体的信息,先设置为多选,SelectMode右键选择Multiple添加一个组和字符串对字符串里的Width进行设置,设置为Standard设置组的名称为属性设置字符串的标题为对象名称将PresentationStyle设置为Combo,格式为下拉框,将ListItems设置为自己的内容,并在Value设置初始值,这一步根据自己的需求进行更改。
2024-09-10 15:13:29
945
原创 NXOpenC属性操作
查看属性,文件->属性使用VS创建项目,找到do_it(),在do_it()里面进行修改删除属性,使用UF_ATTR_delete(),第一个参数是部件的TAG,第二个参数是属性的类型,第三个属性名字。下标是属性类型运行结果:删除所有属性,有一些属性是不能删除的运行结果:创建或修改属性使用UF_ATTR_assign()创建,第一个参数是部件的TAG值,第二个是属性名称,第三个是UF_ATTR_value_t类型,用于存储属性的类型和值查找属性。
2024-09-07 10:04:18
908
原创 NX二次开发—进阶(二)
在NX上通过代码画出圆弧,定义起始和终止位置,还有圆心位置和半径创建圆弧,需要获取CSYS的矩阵ID,通过UF_CURVE_create_arc函数进行创建。
2024-09-07 09:34:36
1317
原创 NX二次开发——进阶(一)
使用UF_UI_write_listing_window(msg),msg需为char *结构,其它类型需要转换,使用sprintf();3.在所有的边找竖直边(两个点的X和Y坐标相同的边是竖边,也可以是两个点的Z坐标相减的绝对值大于0)块创建的时候,原点是以绝对坐标为参考,边的方向是以工作坐标系为参考。1.创建一个块,这块得到的是它的特征的tag。需要将工作坐标系的原点设置为(0,0,0)当工作坐标系的原点不在(0,0,0)时。输入矩阵的ID,能够获得矩阵的值。得到的矩阵的值是经过单位化的值。
2024-09-06 15:03:44
1130
原创 NX二次开发——基础
在NX中,tag_t是 NX对象法人句柄,即任何确定存在的NX对象的唯一标识。在此过程中,句柄的实际值对程序来说是无关紧要的。看到这两种格式,一般不用定义成这样,在定义的时候,是直接把*或者p给去掉,然后在后面引用的时候用取址&符号就可以。UC1601是将想显示的内容显示在一个UI消息框中,或者是状态栏,如果内容很多的时候,就不适合使用UC1601。要实现这个功能具有的逻辑,先是要打开信息窗口,在写内容,如果只打开,不写,打开就是一个空的。生成解决方案,打开NX,Ctrl+U,选择生成的.dll文件打开。
2024-09-03 15:50:35
1004
原创 value-initialization of reference type ‘nlohmann::basic_json<>&’的错误
使用json出现这个错误,是因为gcc的版本问题,我的是4.8版本。解决办法就是更改gcc版本,我更改的版本是9.3。
2023-06-30 15:03:11
693
原创 VScode远程连接运行json库和muduo库出现的错误
我的解决方案是使用终端输入命令g++ testjson.cpp -o testjson -std=c++11进行编译,生成一个testjson运行这个就可以。直接使用vscode运行代码出现以下错误。
2023-06-27 16:37:23
409
原创 linux下搭建muduo环境
把inlcude(头文件)和lib(库文件)目录下的文件拷贝到系统目录下。然后使用root用户下载cmake,下载完执行build.sh。编译完成后,在输入./build.sh install命令。完成后,进入到release-install-cpp11。查看目录,进入CMakeLists.txt。将这行注释掉,然后保存并退出。
2023-06-21 15:50:29
366
原创 在Linux上搭建boost库环境
先将boost源码包拷贝到Linux下的一个目录中,然后进行解压。然后安装,需要切换到root用户(su root)运行bootstrap.sh工程编译构建程序。
2023-06-21 15:13:49
658
3
原创 centos连接XShell
查看网络是否与centos互通,我的centos的IP地址是192.168.129.129,打开Windows的cmd输入ping+IP地址,显示互通正常。最后鼠标右键点击桌面,选择打开终端,输入“ifconfig”,查看Ip是否正常连接。先设置网络自动连接,为Xshell 连接centos做准备。打开安装好的xshell,点击新建(我这里下载的是6)选择网络,如果有线没有打开,选择打开,在点击设置。记住ipv4地址,选择自动连接,然后应用。点击键盘,选择ASCLL,然后点击连接。
2023-06-21 13:53:23
1664
原创 centos7虚拟机安装
点击创建用户,设置一个普通用户,除非修改系统配置,一般都通过普通用户权限使用Linux,更加安全(这一步可以在上一步进行,设置完root密码创建用户,我的是还没创建就安装完了,只能在这步创建)左侧选择带GUI的服务器,右侧选择兼容性程序库、开发工具、安全性工具和系统管理工具,然后点击完成。鼠标点进去,选择第一个,回车开始安装(点击CTRL和alt可以将鼠标转换到windows中)设置密码,点击完成(如果密码简单,会提醒,点击两次完成就可以)填写用户名和设置密码,点击完成,密码简单点击两次完成即可。
2023-06-20 17:05:53
945
原创 C++贪心——跳跳
这一天,你和朋友小 F 一起出去玩耍的时候,遇到了一堆高矮不同的石头,其中第 i块的石头高度为 hi,地面的高度是 h0=0。你估计着,从第 i 块石头跳到第 j块石头上耗费的体力值为 (h_i - h_j) ^ 2,从地面跳到第 i 块石头耗费的体力值是 (h_i) ^ 2。为了给小 F 展现你超级跳的本领,你决定跳到每个石头上各一次,并最终停在任意一块石头上,并且小跳蛙想耗费。分析:想要消耗的体力最大,就应该选择高度相差大的,将高度按照升序的顺序排序,头尾依次的跳,计算体力。
2022-09-19 17:02:47
290
原创 C++贪心——纪念品分组
为使得参加晚会的同学所获得 的纪念品价值相对均衡,他要把购来的纪念品根据价格进行分组,但每组最多只能包括两件纪念品, 并且每组纪念品的价格之和不能超过一个给定的整数。为了保证在尽量短的时间内发完所有纪念品,乐乐希望分组的数目最少。将数据存放到数组中,进行升序的排序,将小的价格跟大的价格发放到一个组里,并且保证满足不超过给定的数。你的任务是写一个程序,找出所有分组方案中分组数最少的一种,输出最少的分组数目。第二行为一个整数 n,表示购来的纪念品的总件数 G。一个整数,即最少的分组数目。
2022-09-19 16:36:43
1354
原创 C++贪心——混合牛奶
此外,就像每头奶牛每天只能挤出固定数量的奶,每位奶农每天能提供的牛奶数量是一定的。每天 Marry 乳业可以从奶农手中采购到小于或者等于奶农最大产量的整数数量的牛奶。给出 Marry 乳业每天对牛奶的需求量,还有每位奶农提供的牛奶单价和产量。接下来 m 行,每行两个整数 pi,ai,表示第 i个农民牛奶的单价,和农民 i 一天最多能卖出的牛奶量。单独的一行包含单独的一个整数,表示 Marry 的牛奶制造公司拿到所需的牛奶所要的最小费用。第一行二个整数 n,m,表示需要牛奶的总量,和提供牛奶的农民个数。
2022-09-19 16:09:22
725
原创 C++贪心——陶陶摘苹果(升级版)
现在已知 n 个苹果到达地上的高度 xi,椅子的高度 a,陶陶手伸直的最大长度 b,陶陶所剩的力气 s,陶陶摘一个苹果需要的力气 yi,求陶陶最多能摘到多少个苹果。这次与 NOIp2005 普及组第一题不同的是:陶陶之前搬凳子,力气只剩下 s了。第 3行~第 3+n−1 行:每行两个数 苹果高度 xi,摘这个苹果需要的力气 yi。先摘需要力气小的苹果,创建一个结构体,对力气升序排序,再判断高度。第 2 行:两个数 椅子的高度 a,陶陶手伸直的最大长度 b。第 1行:两个数 苹果数 n,力气 s。
2022-09-19 14:37:45
475
原创 C++贪心——糖果
先判断前一个数是否大于x,如果大于x,则将这个数等于这个数减去x,后面的数就等于0,吃掉的糖果等于第一个数减去x的值;如果不大于x,则判断两个数相加是否大于x,如果大于,吃掉的糖果数等于两个数相加的和减去x,第二个数等于x-第一个数。(第二个数应该等于这个数减去吃掉糖果的数量,吃掉的糖果数等于两个数相加的和减去x,整理完就是x减去第一个数值。小 A 每次可以从其中一盒糖果中吃掉一颗,他想知道,要让任意两个相邻的盒子中糖的个数之和都不大于 x,至少得吃掉几颗糖。输出一行一个整数,代表最少要吃掉的糖果的数量。
2022-09-19 10:50:04
923
原创 C++贪心——排队接水
最短的排队顺序应该是将小数放到后面,大数在后面。使后面的等待时间少一些。平均等待时间应该是,将每个人的等待时间乘上后面等待的人数在加一起除以人数。有 n 个人在一个水龙头前排队接水,假如每个人接水的时间为 Ti,请编程找出这 n 个人排队的一种顺序,使得 n 个人的平均等待时间最小。输出文件有两行,第一行为一种平均时间最短的排队顺序;第二行为这种排列方案下的平均等待时间(输出结果精确到小数点后两位)。第二行 n 个整数,第 i个整数 Ti 表示第 i 个人的等待时间 Ti。第一行为一个整数 n。
2022-09-16 09:48:38
2430
原创 C++贪心——部分背包
藏宝洞里面有 N(N≤100) 堆金币,第 i 堆金币的总重量和总价值分别是 mi,vi(1≤mi,vi≤100)。阿里巴巴有一个承重量为 T(T≤1000) 的背包,但并不一定有办法将全部的金币都装进去。他想装走尽可能多价值的金币。所有金币都可以随意分割,分割完的金币重量价值比(也就是单位价格)不变。价值还有两个之间的比值。计算放到背包中金币的重量和价值。因为金币可以随意分割,因此当重量大于背包的承重量时,应该把多余的重量减去,加上分割完的价值。接下来 N行,每行两个整数 mi,vi。
2022-09-16 08:58:32
324
原创 C++暴力枚举——三连击(升级版)
9 共 9 个数分成三组,分别组成三个三位数,且使这三个三位数的比例是 A:B:C,试求出所有满足条件的三个三位数,若无解,输出。把符合ABC比例的数字找出,判断是否满足每个数字不重复,如果不重复就输出。没有满足的数字,出去No!若干行,每行 3 个数字。按照每行第一个数字升序排列。三个数,A,B,C。
2022-09-14 16:16:40
1409
原创 C++暴力枚举——烤鸡
猪猪 Hanke 特别喜欢吃烤鸡(本是同畜牲,相煎何太急!因为他有 10 种配料(芥末、孜然等),每种配料可以放 1 到 3 克,任意烤鸡的美味程度为所有配料质量之和。现在, Hanke 想要知道,如果给你一个美味程度 n ,请输出这 10 种配料的所有搭配方案。分析:用for循环进行暴力枚举,注意n小于10或者大于30是没有符合要求的。第二行至结束,10个数,表示每种配料所放的质量,按字典序排列。如果没有符合要求的方法,就只要在第一行输出一个 0。一个正整数 n,表示美味程度。
2022-09-14 10:31:49
1492
原创 C++排序——拼数
设有 n个正整数 a1…an,将它们联接成一排,相邻数字首尾相接,组成一个最大的整数。分析:创建一个字符串数组进行排序,排序的方式是,a+b大于b+a就将a放前。第二行有 n 个整数,表示给出的 n 个整数 ai。第一行有一个整数,表示数字个数 n。一个正整数,表示最大的整数。
2022-09-13 15:50:49
921
原创 C++排序——生日
cjf 君想调查学校 OI 组每个同学的生日,并按照年龄从大到小的顺序排序。但 cjf 君最近作业很多,没有时间,所以请你帮她排序。即 n 个生日从大到小同学的姓名。(如果有两个同学生日相同,输入靠后的同学先输出)第 2 行至第 n+1行分别是每人的姓名 s、出生年 y、月 m、日 d。创建一个结构体并排序,按照生日的大小排序,若是生日一样,后输入的在前。第 1 行为 OI 组总人数 n;
2022-09-13 15:47:41
2503
原创 C++排序——攀爬者
他在地形图上标记了 N个点,每个点Pi 都有一个坐标 (xi,yi,zi)。(3) HKE 会飞,他从一个点Pi 爬到 Pj 的距离为两个点的欧几里得距离。即,$\sqrt{(X_i-X_j)^2+(Y_i-Y_j)^2+(Z_i-Z_j)^2}$根据题意,创建一个结构体,按照点的大小进行排序,然后根据欧几里得距离公式计算高度,将高度加在一起。接下来 N 行,三个整数 xi,yi,zi 表示第 i 个点的坐标。(2) 从第二个点开始,他经过的每一个点高度 zz 都比上一个点高;
2022-09-13 11:12:52
596
原创 C++排序——分数线划定
面试分数线根据计划录取人数的 150% 划定,即如果计划录取 m 名志愿者,则面试分数线为排名第 m×150%(向下取整)名的选手的分数,而最终进入面试的选手为笔试成绩不低于面试分数线的所有选手。第一行,两个整数 n,m(5≤n≤5000,3≤m≤n),中间用一个空格隔开,其中 n 表示报名参加笔试的选手总数,m表示计划录取的志愿者人数。从第二行开始,每行包含 2个整数,中间用一个空格隔开,分别表示进入面试的选手的报名号和笔试成绩,按照笔试成绩从高到低输出,如果成绩相同,则按报名号由小到大的顺序输出。
2022-09-13 10:08:43
1316
原创 C++排序——欢乐的跳
一个 n个元素的整数数组,如果数组两个连续元素之间差的绝对值包括了 [1,n−1] 之间的所有整数,则称之符合“欢乐的跳”,如数组 {1,4,2,3} 符合“欢乐的跳”,因为差的绝对值分别为:3,2,1。每组测试数据第一行以一个整数 n(1≤n≤1000) 开始,接下来 n 个空格隔开的在 [−108,108] 之间的整数。分析:循环对俩个相邻的数相减的绝对值进行判断,是否在1到n-1之间,在就返回jolly,不在就输出not jolly。给定一个数组,你的任务是判断该数组是否符合“欢乐的跳”。
2022-09-09 11:11:05
768
原创 C++排序——车厢重组
在一个旧式的火车站旁边有一座桥,其桥面可以绕河中心的桥墩水平旋转。一个车站的职工发现桥的长度最多能容纳两节车厢,如果将桥旋转 180 度,则可以把相邻两节车厢的位置交换,用这种方法可以重新排列车厢的顺序。于是他就负责用这座桥将进站的车厢按车厢号从小到大排列。他退休后,火车站决定将这一工作自动化,其中一项重要的工作是编一个程序,输入初始的车厢顺序,计算最少用多少步就能将车厢排序。分析:对给的数据进行从大到小排序,只能挨着的两个数进行交换。第二行是 N 个不同的数表示初始的车厢顺序。一个整数,最少的旋转次数。
2022-09-09 09:50:52
1685
1
原创 C++排序——Bookshelf B
为了够到比最高的那头奶牛还要高的书架顶,奶牛们不得不像演杂技一般,一头站在另一头的背上,叠成一座“奶牛塔”。当然,这个塔的高度,就是塔中所有奶牛的身高之和。为了往书架顶上放东西,所有奶牛的身高和必须不小于书架的高度。书架的高度为B,并且保证 1≤B≤S
2022-09-08 17:19:23
503
原创 C++模拟与高精度——帮贡排序
现在 absi2011 和帮主等人联合决定,要清除一些死号,加进一些新号,同时还要鼓励帮贡多的人,对帮派进行一番休整。他按原来的顺序给你(所以,等级相同的,原来靠前的现在也要靠前,因为经验高低的原因,但此处为了简单点省去经验。他发现这是个很难的事情。目前帮派内共最多有一位帮主,两位副帮主,两位护法,四位长老,七位堂主,二十五名精英,帮众若干。先按照帮贡排序,分出职务,在根据职务相同的,按照等级排序,等级一样,按输入顺序排序。他的名字(长度不会超过 30),他的原来职位,他的帮贡,他的等级。
2022-09-07 16:06:38
397
原创 C++模拟与高精度——字符串展开
(4) 参数 p3:是否改为逆序:p3=1 表示维持原来顺序,p3=2 表示采用逆序输出,注意这时候仍然不包括减号两端的字符。注意:"-"号后面的应该大于前面的,如果前面是字母,后面是数字是满足字母条件的,比如s-4就满足前一个字母大于等于a,后一个字母小于等于z。的字串,我们就把它当作一种简写,输出时,用连续递增的字母或数字串替代其中的减号,即,将上面两个子串分别输出为。在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于。减号两边的字符不变。
2022-09-06 17:37:34
499
原创 C++模拟与高精度——多项式输出
请按照如下规定的格式要求输出该多项式:多项式中自变量为 x,从左到右按照次数递减顺序给出多项式。多项式中只包含系数不为 0的项。如果多项式 nn 次项系数为正,则多项式开头不出+号,如果多项式 n次项系数为负,则多项式以-号开头。对于不是最高次的项,以+号或者-号连接此项与前一项,分别表示此项系数为正或者系数为负。紧跟一个正整数,表示此项系数的绝对值(如果一个高于 0 次的项,其系数的绝对值为 1,则无需输出 1)。
2022-09-03 16:13:09
262
原创 C++模拟与高精度——生活大爆炸版石头剪刀布
例如:如果小 A 以“石头-布-石头-剪刀-蜥蜴人-斯波克”长度为 6的周期出拳,那么他的出拳序列就是“石头-布-石头-剪刀-蜥蜴人-斯波克-石头-布-石头-剪刀-蜥蜴人-斯波克-......”,而如果小 B 以“剪刀-石头-布-斯波克-蜥蜴人”长度为 5 的周期出拳,那么他出拳的序列就是“剪刀-石头-布-斯波克-蜥蜴人-剪刀-石头-布-斯波克-蜥蜴人-......”数与数之间以一个空格分隔。第一行包含三个整数:N,NA,NB,分别表示共进行 N次猜拳、小 A 出拳的周期长度,小 B 出拳的周期长度。
2022-09-03 15:08:21
587
原创 C++模拟与高精度——魔法少女小Scarlet
以表格中的2为例子,在矩阵中的位置为(1,2),顺时针旋转变成6也就是(2,3),第1行的第2个变成倒数第1列的第2个,即第i行第j个的变成倒数第i列第j个,如果是逆时针旋转,第i行第j个变成第i列倒数第j个。接下来 m 行,每行 4 个整数 x,y,r,z,表示在这次魔法中,Scarlet 会把以第 x行第 y 列为中心的 2r+1 阶矩阵按照某种时针方向旋转,其中z=0 表示顺时针,z=1 表示逆时针。输出 n行,每行 n 个用空格隔开的数,表示最终所得的矩阵。针对矩阵旋转,如果是顺时针旋转90°。
2022-09-03 10:41:20
426
原创 C++排序——宇宙总统
题目描述地球历公元 6036 年,全宇宙准备竞选一个最贤能的人当总统,共有 n个非凡拔尖的人竞选总统,现在票数已经统计完毕,请你算出谁能够当上总统。输入格式第一行为一个整数 n,代表竞选总统的人数。接下来有 n行,分别为第一个候选人到第 n 个候选人的票数。输出格式共两行,第一行是一个整数 m,为当上总统的人的号数。第二行是当上总统的人的选票。分析:这道题就是找出票数最大的,但是票数很大,我用的是字符串保存票数,只保留最大的,先对票数进行位数比较,位数多的指定大,在对同位
2022-05-07 16:35:51
3152
原创 C++排序——奖学金
题目描述某小学最近得到了一笔赞助,打算拿出其中一部分为学习成绩优秀的前5名学生发奖学金。期末,每个学生都有3门课的成绩:语文、数学、英语。先按总分从高到低排序,如果两个同学总分相同,再按语文成绩从高到低排序,如果两个同学总分和语文成绩都相同,那么规定学号小的同学 排在前面,这样,每个学生的排序是唯一确定的。任务:先根据输入的3门课的成绩计算总分,然后按上述规则排序,最后按排名顺序输出前五名名学生的学号和总分。注意,在前5名同学中,每个人的奖学金都不相同,因此,你必须严格按上述规则排序。例如,在某个正
2022-05-06 20:46:41
989
空空如也
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人