导航:首页 > 源码编译 > 反算法和极坐标法

反算法和极坐标法

发布时间:2023-07-26 12:26:11

❶ 省考行测:反算法

在广东省考行测资料分析题目中,经常会遇到一些列式之后和一个比较整的数据比较大小的题目,此时我们可以化除为乘,化减为加,不用计算很多不整的数据,从而简化运算。

例1:2017年粮食产量为a,2016年为b。问:增长率是否超过20%?

中公解析:粮食产量增长率超过20%,即(a-b)÷b>20%。将除法转乘法,得到a-b>0.2b,即a-b>0.2b时,2017年增长率超过20%。

这种方法就叫反算法,通过分析题干特点,将题目进行巧妙转化从而简化计算。

可以利用反算法的题型一般会具有以下特点:题干要求满足某个或某些条件的指标个数,通常是指两数之比或增长率在某个范围内,给出的比值一般简单易算。

具体使用方法可以总结为以下三步:

第一步:将除法转化为乘法;

第二步:检验“>”或“<”关系是否成立;

第三步(视情况而定):若正而计数个数较多,可先从反面计数,再用总数相减。

我们再通过几道例题练习一下。

例2:2017年第一季度,某省农林牧渔业增加值361.78亿元,比上年同期增长5.9%,高于上年同期0.2个百分点,具体情况如下:

该省种植业增加值119.21亿元,比上年同期增长8.2%。林业增加值34.84亿元,比上年同期增长8.3%。畜牧业增加值176.64亿元,比上年同期增长4.2%,增速比上年同期加快2.1个百分点。渔业增加值9.22亿元,比上年同期增长4.5%。农林牧渔服务业增加值21.87亿元,比上年同期增长3.8%。

问题:2017年第一季度,该省占农林牧渔业增加值比重超过三成的包括:

A.种植业、渔业

B.林业、畜牧业

C.种植业、畜牧业

D.农林牧渔服务业、林业

【答案】C。中公解析:根据题干信息判断考查现期比重。比重超过三成,即部分/整体>30%。计算每个指标所占的比重比较耗时,可直接使用反算法,简化计算过程。

首先得到2017年第一季度该省农林牧渔业增加值的三成,为361.78×30%≈362×0.3=108.6亿元。再查找材料中超过该值的只有种植业和畜牧业,分别为l19.21亿元、176.64亿元。故本题选C。

例3:

❷ 员工工资薪酬计算方法

一、正面回答
工资等于月薪除以21.75乘月计薪天数乘出勤天数比例。反算法:工资等于月薪的月薪除以21.75乘缺勤天数乘出勤天数比例。月计薪天数等于月出勤天数加法定节假日天数。出勤天数比例等于21.75除以当月应出勤天数加法定节假日天数。
二、详细分析
薪资结构,即结构工资制,是指按工资的不同功能划分为若干相对独立的工资单元,各单元又规定不同的结构系数,组成有质的区分和量的比例关系的工资结构。结构工资制也是我国企业在工资改革过程中创造出来的一种新的工资制度。
三、员工的工资要怎么给?
工资支付应当以货币形式、按月、按照用人单位与劳动者约定的数额,支付给劳动者本人,由本人签收。用人单位发放工资应该给付工资凭证,严格防止用人单位做假工资单,存折上一部分,现金一部分,以此少缴纳社会保险和住房公积金,少支付经济补偿金。不得克扣或者无故拖欠劳动者工资。推迟30天以上就构成拖欠。工资至少每月支付一次,对于实行小时工资制和周工资制得人员,工资也可以按日或周发放。

❸ 序列号保护加密的原理和验证方法

(1)序列号保护机制

数学算法一项都是密码加密的核心,但在一般的软件加密中,它似乎并不太为人们关心,因为大多数时候软件加密本身实现的都是一种编程的技巧。但近几年来随着序列号加密程序的普及,数学算法在软件加密中的比重似乎是越来越大了。
我们先来看看在网络上大行其道的序列号加密的工作原理。当用户从网络上下载某个shareware——共享软件后,一般都有使用时间上的限制,当过了共享软件的试用期后,你必须到这个软件的公司去注册后方能继续使用。注册过程一般是用户把自己的私人信息(一般主要指名字)连同信用卡号码告诉给软件公司,软件公司会根据用户的信息计算出一个序列码,在用户得到这个序列码后,按照注册需要的步骤在软件中输入注册信息和注册码,其注册信息的合法性由软件验证通过后,软件就会取消掉本身的各种限制,这种加密实现起来比较简单,不需要额外的成本,用户购买也非常方便,在互联网上的软件80%都是以这种方式来保护的。
我们注意到软件验证序列号的合法性过程,其实就是验证用户名和序列号之间的换算关系是否正确的过程。其验证最基本的有两种,一种是按用户输入的姓名来生成注册码,再同用户输入的注册码比较,公式表示如下:
序列号 = F(用户名)
但这种方法等于在用户软件中再现了软件公司生成注册码的过程,实际上是非常不安全的,不论其换算过程多么复杂,解密者只需把你的换算过程从程序中提取出来就可以编制一个通用的注册程序。

另外一种是通过注册码来验证用户名的正确性,公式表示如下:
用户名称 = F逆(序列号) (如ACDSEE,小楼注)
这其实是软件公司注册码计算过程的反算法,如果正向算法与反向算法不是对称算法的话,对于解密者来说,的确有些困难,但这种算法相当不好设计。

于是有人考虑到一下的算法:
F1(用户名称) = F2(序列号)
F1、F2是两种完全不同的的算法,但用户名通过F1算法的计算出的特征字等于序列号通过F2算法计算出的特征字,这种算法在设计上比较简单,保密性相对以上两种算法也要好的多。如果能够把F1、F2算法设计成不可逆算法的话,保密性相当的好;可一旦解密者找到其中之一的反算法的话,这种算法就不安全了。一元算法的设计看来再如何努力也很难有太大的突破,那么二元呢?

特定值 = F(用户名,序列号)
这个算法看上去相当不错,用户名称与序列号之间的关系不再那么清晰了,但同时也失去了用户名于序列号的一一对应关系,软件开发者必须自己维护用户名称与序列号之间的唯一性,但这似乎不是难以办到的事,建个数据库就好了。当然你也可以根据这一思路把用户名称和序列号分为几个部分来构造多元的算法。
特定值 = F(用户名1,用户名2,...序列号1,序列号2...)

现有的序列号加密算法大多是软件开发者自行设计的,大部分相当简单。而且有些算法作者虽然下了很大的功夫,效果却往往得不到它所希望的结果。其实现在有很多现成的加密算法可以用,如RSADES,MD4,MD5,只不过这些算法是为了加密密文或密码用的,于序列号加密多少有些不同。我在这里试举一例,希望有抛砖引玉的作用:
1、在软件程序中有一段加密过的密文S
2、密钥 = F(用户名、序列号) 用上面的二元算法得到密钥
3、明文D = F-DES(密文S、密钥) 用得到的密钥来解密密文得到明文D
4、CRC = F-CRC(明文D) 对得到的明文应用各种CRC统计
5、检查CRC是否正确。最好多设计几种CRC算法,检查多个CRC结果是否都正确
用这种方法,在没有一个已知正确的序列号情况下是永远推算不出正确的序列号的。

(2)如何攻击序列号保护

要找到序列号,或者修改掉判断序列号之后的跳转指令,最重要的是要利用各种工具定位判断序列号的代码段。这些常用的API包括GetDlgItemInt, GetDlgItemTextA, GetTabbedTextExtentA, GetWindowTextA, Hmemcpy (仅仅Windows 9x), lstrcmp, lstrlen, memcpy (限于NT/2000)。

1)数据约束性的秘诀
这个概念是+ORC提出的,只限于用明文比较注册码的那种保护方式。在大多数序列号保护的程序中,那个真正的、正确的注册码或密码(Password)会于某个时刻出现在内存中,当然它出现的位置是不定的,但多数情况下它会在一个范围之内,即存放用户输入序列号的内存地址±0X90字节的地方。这是由于加密者所用工具内部的一个Windows数据传输的约束条件决定的。

2)Hmemcpy函数(俗称万能断点)
函数Hmemcpy是Windows9x系统的内部函数,位于KERNEL32.DLL中,它的作用是将内存中的一块数据拷贝到另一个地方。由于Windows9x系统频繁使用该函数处理各种字串,因此用它作为断点很实用,它是Windows9x平台最常用的断点。在Windows NT/2K中没有这个断点,因为其内核和Windows9x完全不同。

3)S命令
由于S命令忽略不在内存中的页面,因此你可以使用32位平面地址数据段描述符30h在整个4GB(0~FFFFFFFFh )空间查找,一般用在Windows9x下面。具体步骤为:先输入姓名或假的序列号(如: 78787878),按Ctrl+D切换到SoftICE下,下搜索命令:
s 30:0 L ffffffff '78787878'
会搜索出地址:ss:ssssssss(这些地址可能不止一个),然后用bpm断点监视搜索到的假注册码,跟踪一下程序如何处理输入的序列号,就有可能找到正确的序列号。

4)利用消息断点
在处理字串方面可以利用消息断点WM_GETTEXT和WM_COMMAND。前者用来读取某个控件中的文本,比如拷贝编辑窗口中的序列号到程序提供的一个缓冲区里;后者则是用来通知某个控件的父窗口的,比如当输入序列号之后点击OK按钮,则该按钮的父窗口将收到一个WM_COMMAND消息,以表明该按钮被点击。
BMSG xxxx WM_GETTEXT (拦截序列号)
BMSG xxxx WM_COMMAND (拦截OK按钮)
可以用SoftICE提供的HWND命令获得窗口句柄的信息,也可以利用Visual Studio中的Spy++实用工具得到相应窗口的句柄值,然后用BMSG设断点拦截。例:
BMSG 0129 WM_COMMAND

❹ 工资算法是什么呢

工资算法及举例如下。

1、正算法:工资=月薪÷21.75×月计薪天数×(出勤天数比例)。

2、反算法:工资=月薪-月薪÷21.75x缺勤天数×(出勤天数比例)。

3、月计薪天数=(月出勤天数+法定节假日天数)。

4、出勤天数比例=21.75÷(当月应出勤天数+法定节假日天数)。

5、同样举上面的案例。

案例一:某员工月薪2175,7月份有23个工作日,员工缺勤1天,出勤是22天,本月月薪多少。

正算法:2175÷21.75×22×(21.75÷23)=2080.4。

反算法:2175—2175÷21.75×1×(21.75÷23)=2080.4。

案例二:某员工月薪2175元,5月份有21个工作日,5.1为法定节假日,员工缺勤1天,出勤是20天,本月月薪多少。

正算法:2175÷21.75×(20+1)×(21.75÷(21+1))=2076.14。

反算法:2175—2175÷21.75×1×(21.75÷(21+1))=2076.14。

阅读全文

与反算法和极坐标法相关的资料

热点内容
dvd光盘存储汉子算法 浏览:755
苹果邮件无法连接服务器地址 浏览:958
phpffmpeg转码 浏览:669
长沙好玩的解压项目 浏览:140
专属学情分析报告是什么app 浏览:562
php工程部署 浏览:831
android全屏透明 浏览:730
阿里云服务器已开通怎么办 浏览:801
光遇为什么登录时服务器已满 浏览:300
PDF分析 浏览:483
h3c光纤全工半全工设置命令 浏览:140
公司法pdf下载 浏览:381
linuxmarkdown 浏览:350
华为手机怎么多选文件夹 浏览:681
如何取消命令方块指令 浏览:347
风翼app为什么进不去了 浏览:777
im4java压缩图片 浏览:360
数据查询网站源码 浏览:148
伊克塞尔文档怎么进行加密 浏览:888
app转账是什么 浏览:162