数学可以提高思维能力,而算法最需要的就是思维能力,所以数学和算法题总是绕不开的,PAT 中就有专门的数学类型题但只是将需要大量计算的数学题用算法的方式进行解答,但还是有一部分题做到了很好的结合。举个不恰当的例子:圆的面积就是将其不断分割成可以用来计算的矩形和三角形,按照数学的思路就是用圆周率,而算法就是模拟切割的过程不断计算(当然实际肯定不是这样),不过计算机被创造出来的初衷好像就是做这种事
思想解释
简单数学
一些不需要算法,仅仅使用基础数学知识的问题,一般考察的逻辑数理能力
公约公倍数
1 | int gcd(int a, int b) |
最小公倍数:
分数
分数的存储一般使用结构体的方式
1 | struct Fraction |
至于其运算也是使用不同的公式对分数的分子分母进行操作
分数许多情况下需要化简,其化简过程有三个:
-
判断 down 是否为负数,是则使分子和分母都变为其相反数
-
判断分子是否为 0,是则分母化为 1
-
求分子和分母的绝对值是否有最大公约数,有则转换为除公约数的情况
分数的输出有多种情况,输出前必须化简
-
需要判断分母是否为 1,是则输出整数
-
分子的绝对值大于分母,则是一个假分数,输出带分数的形式
素数
判断代码:
1 | bool isPrime(int a) |
手动表:
1 | vector<int> prime(50000, 1); |
质因子
一个整数被分解成一个或多个质数的乘积,但是质因子相乘到 29 时 () 就已经超过了 int 型的范围,所以保存因子的数组大小为 10 即可
大数存储与运算
大数使用读入字符串,反向存储到 int 数组中,运算根据规则定义即可
1 |
|
类型练习
1069
题目:The Black Hole of Numbers
For any 4-digit integer except the ones with all the digits being the same, if we sort the digits in non-increasing order first, and then in non-decreasing order, a new number can be obtained by taking the second number from the first one. Repeat in this manner we will soon end up at the number 6174
– the black hole of 4-digit numbers. This number is named Kaprekar Constant.
For example, start from 6767
, we’ll get:
7766 - 6677 = 1089
9810 - 0189 = 9621
9621 - 1269 = 8352
8532 - 2358 = 6174
7641 - 1467 = 6174
… …
Given any 4-digit number, you are supposed to illustrate the way it gets into the black hole.
Input Specification:
Each input file contains one test case which gives a positive integer N in the range .
Output Specification:
If all the 4 digits of N are the same, print in one line the equation N - N = 0000
. Else print each step of calculation in a line until 6174
comes out as the difference. All the numbers must be printed as 4-digit numbers.
Sample Input 1:
6767
Sample Output 1:
7766 - 6677 = 1089
9810 - 0189 = 9621
9621 - 1269 = 8352
8532 - 2358 = 6174
Sample Input 2:
2222
Sample Output 2:
2222 - 2222 = 0000
思路: 使用字符串的形式进行输入,对字符串进行升序和降序排序,转换为整数求结果,再将结果转换为字符串判断是否为 6174 或 0000
代码:
1 |
|
1104
题目:Sum of Number Segments
Given a sequence of positive numbers, a segment is defined to be a consecutive subsequence. For example, given the sequence {0.1, 0.2, 0.3, 0.4}, we have 10 segments: (0.1) (0.1, 0.2) (0.1, 0.2, 0.3) (0.1, 0.2, 0.3, 0.4) (0.2) (0.2, 0.3) (0.2, 0.3, 0.4) (0.3) (0.3, 0.4) and (0.4).
Now given a sequence, you are supposed to find the sum of all the numbers in all the segments. For the previous example, the sum of all the 10 segments is .
Input Specification:
Each input file contains one test case. For each case, the first line gives a positive integer N, the size of the sequence which is no more than 105. The next line contains N positive numbers in the sequence, each no more than 1.0, separated by a space.
Output Specification:
For each test case, print in one line the sum of all the numbers in all the segments, accurate up to 2 decimal places.
Sample Input:
4
0.1 0.2 0.3 0.4
Sample Output:
5.00
思路: 找出每个数字在不同片段出现的次数,规律为 ,注意精度可能不足
代码:
1 |
|
1008
题目:Elevator
The highest building in our city has only one elevator. A request list is made up with N positive numbers. The numbers denote at which floors the elevator will stop, in specified order. It costs 6 seconds to move the elevator up one floor, and 4 seconds to move down one floor. The elevator will stay for 5 seconds at each stop.
For a given request list, you are to compute the total time spent to fulfill the requests on the list. The elevator is on the 0th floor at the beginning and does not have to return to the ground floor when the requests are fulfilled.
Input Specification:
Each input file contains one test case. Each case contains a positive integer N, followed by N positive numbers. All the numbers in the input are less than 100.
Output Specification:
For each test case, print the total time on a single line.
Sample Input:
3 2 3 1
Sample Output:
41
思路: 循环处理,根据大小关系处理上楼下楼,每次更新 now 代表的楼层
代码:
1 |
|
1049
题目:Counting Ones
The task is simple: given any positive integer N, you are supposed to count the total number of 1’s in the decimal form of the integers from 1 to N. For example, given N being 12, there are five 1’s in 1, 10, 11, and 12.
Input Specification:
Each input file contains one test case which gives the positive .
Output Specification:
For each test case, print the number of 1’s in one line.
Sample Input:
12
Sample Output:
5
思路: 直接循环必然超时,总结规律:从第一位(个位)到最高位,设 now 为当前位的数字,left 为 now 左边的所有数字构成的数字,right 是 now 右边的所有数字构成的数字。只需要一次次累加对于当前位 now 来说可能出现 1 的个数,然后把它们累加即可。a 表示当前的个位为 1,十位为 10,百位为 100 类推。
对于 now,有三种情况:
-
now == 0 : 那么 ans += left * a; // 因为 now==0 说明 now 位只有在 left 从 0~left-1 的时候会产生 1,所以会产生 left 次,但是又因为右边会重复从 0~999… 出现 a 次
-
now == 1 : ans += left * a + right + 1;//now = 1 的时候就要比上一步多加一个当 now 为 1 的时候右边出现 0~right 个数导致的 now 为 1 的次数
-
now >= 2 : ans += (left + 1) * a;//now 大于等于 2 就左边 0~left 的时候会在 now 位置产生 1,所以会产生 left 次,但是又因为右边会重复从 0~999… 出现 a 次
代码:
1 |
|
1081
题目:Rational Sum
Given N rational numbers in the form numerator/denominator
, you are supposed to calculate their sum.
Input Specification:
Each input file contains one test case. Each case starts with a positive integer N (≤100), followed in the next line N rational numbers a1/b1 a2/b2 ...
where all the numerators and denominators are in the range of long int. If there is a negative number, then the sign must appear in front of the numerator.
Output Specification:
For each test case, output the sum in the simplest form integer numerator/denominator
where integer
is the integer part of the sum, numerator
< denominator
, and the numerator and the denominator have no common factor. You must output only the fractional part if the integer part is 0.
Sample Input 1:
5
2/5 4/15 1/30 -2/60 8/3
Sample Output 1:
3 1/3
思路: 根据文首分数的处理思路,对其进行处理即可
代码:
1 |
|
1088
题目:Rational Arithmetic
For two rational numbers, your task is to implement the basic arithmetics, that is, to calculate their sum, difference, product and quotient.
Input Specification:
Each input file contains one test case, which gives in one line the two rational numbers in the format a1/b1 a2/b2
. The numerators and the denominators are all in the range of long int. If there is a negative sign, it must appear only in front of the numerator. The denominators are guaranteed to be non-zero numbers.
Output Specification:
For each test case, print in 4 lines the sum, difference, product and quotient of the two rational numbers, respectively. The format of each line is number1 operator number2 = result
. Notice that all the rational numbers must be in their simplest form k a/b
, where k
is the integer part, and a/b
is the simplest fraction part. If the number is negative, it must be included in a pair of parentheses. If the denominator in the division is zero, output Inf
as the result. It is guaranteed that all the output integers are in the range of long int.
Sample Input 1:
2/3 -4/2
Sample Output 1:
2/3 + (-2) = (-1 1/3)
2/3 - (-2) = 2 2/3
2/3 * (-2) = (-1 1/3)
2/3 / (-2) = (-1/3)
Sample Input 2:
5/3 0/6
Sample Output 2:
1 2/3 + 0 = 1 2/3
1 2/3 - 0 = 1 2/3
1 2/3 * 0 = 0
1 2/3 / 0 = Inf
思路: 使用上方分数思想编写不同的算法函数进行运算即可,这里采用的是柳神代码
代码:
1 |
|
1078
题目:Hashing
The task of this problem is simple: insert a sequence of distinct positive integers into a hash table, and output the positions of the input numbers. The hash function is defined to be where TSize is the maximum size of the hash table. Quadratic probing (with positive increments only) is used to solve the collisions.
Note that the table size is better to be prime. If the maximum size given by the user is not prime, you must re-define the table size to be the smallest prime number which is larger than the size given by the user.
Input Specification:
Each input file contains one test case. For each case, the first line contains two positive numbers: and which are the user-defined table size and the number of input numbers, respectively. Then N distinct positive integers are given in the next line. All the numbers in a line are separated by a space.
Output Specification:
For each test case, print the corresponding positions (index starts from 0) of the input numbers in one line. All the numbers in a line are separated by a space, and there must be no extra space at the end of the line. In case it is impossible to insert the number, print “-” instead.
Sample Input:
4 4
10 6 4 15
Sample Output:
0 1 4 -
思路: 找到大于 Tsize 的最小的素数,然后使用二次探查法
如果 hashTable 里面 key % size 的下标对应的 hashTable 为 false, 说明这个下标没有被使用过,直接输出。否则 step 步长从 1 加到 size-1,一次次尝试是否能使 index = (key + step * step) % size; 所对应的位置没有元素,如果都没有找到就输出“-”,否则就输出这个找到的元素的位置
注意 是 (key + step * step) % size 而不是 ** (key % size + step * step)
代码:
1 |
|
1096
题目:Consecutive Factors
Among all the factors of a positive integer N, there may exist several consecutive numbers. For example, 630 can be factored as , where 5, 6, and 7 are the three consecutive numbers. Now given any positive N, you are supposed to find the maximum number of consecutive factors, and list the smallest sequence of the consecutive factors.
Input Specification:
Each input file contains one test case, which gives the integer .
Output Specification:
For each test case, print in the first line the maximum number of consecutive factors. Then in the second line, print the smallest sequence of the consecutive factors in the format factor[1]*factor[2]*...*factor[k]
, where the factors are listed in increasing order, and 1 is NOT included.
Sample Input:
630
Sample Output:
3
5×6×7
思路: 使用双重循环嵌套,模拟连续的长度,不论长度多少,当前乘积不能被 num 整除就不符合条件,相反,只要能够整除不论其他因子为多少都符合条件
-
数据规模为 int 型的范围,但中间计算乘积时可能导致溢出,所以存储为 long long
-
因子 1 不包含在范围中,第一层循环从 2 开始,然后将第一层的变量 i 作为第二层循环的起始因子,不断自增模拟
-
使用临时变量 temp(每次初始为 1)相乘第二层的循环变量 j,若 num 对 temp 不能整除,表示不符合条件跳出
代码:
1 |
|
1059
题目:Prime Factors
Given any positive integer N, you are supposed to find all of its prime factors, and write them in the format .
Input Specification:
Each input file contains one test case which gives a positive integer N in the range of long int.
Output Specification:
Factor N in the format N =
p1^
k1*
p2^
k2*
…*
pm^
km, where pi’s are prime factors of N in increasing order, and the exponent ki is the number of pi – hence when there is only one pi, ki is 1 and must NOT be printed out.
Sample Input:
97532468
Sample Output:
97532468=2^211171011291
思路: 建立素数表,遍历判断,符合条件整除当前因子后继续判断
-
建立素数表:long int 的 sqrt 最大不超过 50000,也就是说因子只会在这里边产生,将数组初始值为 1,不符合条件的赋值为 0
-
循环遍历,然后对每一个变量 i 进行素数判断,是素数就判断能否整除,能够整除在判断一次,判断当前因子出现了几次
代码:
1 |
|
1023
题目:Have Fun with Numbers
Notice that the number 123456789 is a 9-digit number consisting exactly the numbers from 1 to 9, with no duplication. Double it we will obtain 246913578, which happens to be another 9-digit number consisting exactly the numbers from 1 to 9, only in a different permutation. Check to see the result if we double it again!
Now you are suppose to check if there are more numbers with this property. That is, double a given number with k digits, you are to tell if the resulting number consists of only a permutation of the digits in the original number.
Input Specification:
Each input contains one test case. Each case contains one positive integer with no more than 20 digits.
Output Specification:
For each test case, first print in a line “Yes” if doubling the input number gives a number that consists of only a permutation of the digits in the original number, or “No” if not. Then in the next line, print the doubled number.
Sample Input:
1234567899
Sample Output:
Yes
2469135798
思路: 大数类的转换和乘法,使用标记数组进行每个字符次数的判断
代码:
1 |
|
1024
题目:Palindromic Number
A number that will be the same when it is written forwards or backwards is known as a Palindromic Number. For example, 1234321 is a palindromic number. All single digit numbers are palindromic numbers.
Non-palindromic numbers can be paired with palindromic ones via a series of operations. First, the non-palindromic number is reversed and the result is added to the original number. If the result is not a palindromic number, this is repeated until it gives a palindromic number. For example, if we start from 67, we can obtain a palindromic number in 2 steps: 67 + 76 = 143, and 143 + 341 = 484.
Given any positive integer N, you are supposed to find its paired palindromic number and the number of steps taken to find it.
Input Specification:
Each input file contains one test case. Each case consists of two positive numbers N and K, where is the initial numer and K (≤100) is the maximum number of steps. The numbers are separated by a space.
Output Specification:
For each test case, output two numbers, one in each line. The first number is the paired palindromic number of N, and the second number is the number of steps taken to find the palindromic number. If the palindromic number is not found after K steps, just output the number obtained at the Kth step and K instead.
Sample Input 1:
67 3
Sample Output 1:
484
2
思路: 将操作的方法独立编写,使用次数和是否回文作为循环终止条件进行 while 循环,最后输出
代码:
1 |
|
- 本文标题:PAT 甲级 - 数学问题
- 本文作者:Aidan
- 创建时间:2021-08-13 21:51:59
- 本文链接:https://aidanblog.top/pat_level_a-math_problem/
- 版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!