试题编号: 202309-2
试题名称: 坐标变换(其二)
时间限制: 2.0s
内存限制: 512.0MB
问题描述:
问题描述
样例输入:
10 5
2 0.59
2 4.956
1 0.997
1 1.364
1 1.242
1 0.82
2 2.824
1 0.716
2 0.178
2 4.094
1 6 -953188 -946637
1 9 969538 848081
4 7 -114758 522223
1 9 -535079 601597
8 8 159430 -511187
样例输出
-1858706.758 -83259.993
-1261428.46 201113.678
-75099.123 -738950.159
-119179.897 -789457.532
114151.88 -366009.892
import math
n,m = map(int,input().split())
#设置前缀积的初始化
an = []
an.append([1,0])
for i in range(n):#存入执行每一步之后的拉伸和旋转参数
kind,act = input().split()
if kind == '1':#如果是拉伸
temp1 = an[i][0]*float(act)
temp2 = an[i][1]
an.append([temp1,temp2])
else:#如果是旋转
temp2 = an[i][1]+float(act)
temp1 = an[i][0]
an.append([temp1, temp2])
for v in range(m):#开始切片操作执行
i,j,x,y = map(int,input().split())
k = an[j][0] / an[i-1][0]#对于拉伸做除法
c = an[j][1] - an[i-1][1]#对于旋转做减法
dx = k*(x*math.cos(c) - (y*math.sin(c)))
dy = k*(x*math.sin(c) + (y*math.cos(c)))
print("{:.3f} {:.3f}".format(dx,dy))
【问题描述】给定一个N×M的矩阵A,请你统计有多少个子矩阵 (最小1×1,最大N×M) ,满足子矩阵中所有数的和不超过给定的整数K?
【输入格式】第一行包含三个整数N, M和K,之后N行每行包含M个整数,代表矩阵A
【样例输入】
3 4 10
1 2 3 4
5 6 7 8
9 10 11 12
【样例输出】
19
【评测用例规模与约定】
30%的数据,N, M≤20 5分
70%的数据,N, M≤100 10分
100%的数据,1≤N, M≤500 15分
0≤Ai j≤1000; 1≤K≤250000000
若s[j2] - s[j1] ≤ k,那么在子区间[j1, j2]上,有j2 - j1+1个子区间满足≤ k。用同向扫描的尺取法,用滑动窗口[j1, j2]遍历,复杂度降为O(n)。
对于二维,矩阵的行子区间和仍用2重暴力遍历只把列区间和用尺取法优化。
3. 上代码!!!
n, m, k = map(int, input().split())
a = [[0] for i in range(n)]
a.insert(0,[0]*(m+1))
for i in range(1,n+1): #从a[1][1]开始,读矩阵
a[i].extend(map(int, input().split()))
s = [[0]*(m+1) for i in range(n+1)]
for i in range(1,n+1):
for j in range(1,m+1):
s[i][j] = s[i-1][j] + a[i][j]
ans = 0
for i1 in range(1,n+1):
for i2 in range(i1,n+1):
j1=1; z=0
for j2 in range(1,m+1):
z += s[i2][j2]-s[i1-1][j2]
while z>k:
z -= s[i2][j1]-s[i1-1][j1]
j1 += 1
ans += j2-j1+1
print(ans)