Problem 1: 两个烧杯,一个放糖一个放盐,用勺子舀一勺糖到盐,搅拌均匀,然后舀一勺混合物会放糖的烧杯,问你两个烧杯哪个杂质多?
提示:相同。(1)可以用一个特殊数据计算一下,可以得到两个烧杯里的sugar和salt含量是一样的;
(2)假设杂质不等,那么将杂质放回原杯中,则杯中物体重量必变化,不合理。
Problem 2:如何判断一个点是否在一个多边形内?
提示:将多边形切成很多三角形,判断是不是在某个三角形中;判断是不是在三角形中:(1)可以先找一个点在三角形中,
然后计算这个点和已知点的A*X+B*Y,得到的结果通号就在同一侧,如果与三条线都同侧就在三角形内部。(2)计算已知点和
三角形三边的乘积除2的和是否等于三角形的面积,如果相等就在三角形内部。
Problem 3:
Problem 4:无平方因子的数:给出正整数n和m,区间[n,m]内的“无平方因子”的数有多少个?整数p无平方因子当且仅当不存在k>1,使得p是k^2的
倍数。1<=n<=m<=10^12,m-n<=10^7
提示:参考筛法求素数的算法,复杂度为O(NlogN)
Problem 5:大整数取模:输入正整数n和m,输出n mod m的值。n<=10^100,m<=10^9
提示:mod分解公式,(1) (a+b)mod n = ((a mod n)+(b mod n))mod n (2) (a*b)mod n =(( a mod n)*(