解题思路:
注意事项:
参考代码:
def su(j): l1=[] l2=[] for k in j: if k.isdigit(): l1.append(k) for x in range(int(l1[0])-1,int(l1[2])): for y in range(int(l1[1])-1,int(l1[3])): if not str(l[x][y]).isdigit(): if 'SUM' in l[x][y]: l[x][y]=su(l[x][y]) elif 'AVG' in l[x][y]: l[x][y]=av(l[x][y]) elif 'STD' in l[x][y]: l[x][y]=st(l[x][y]) l2.append(int(l[x][y])) return sum(l2) def av(j): l1=[] l2=[] for k in j: if k.isdigit(): l1.append(k) for x in range(int(l1[0])-1,int(l1[2])): for y in range(int(l1[1])-1,int(l1[3])): if not str(l[x][y]).isdigit(): if 'SUM' in l[x][y]: l[x][y]=su(l[x][y]) elif 'AVG' in l[x][y]: l[x][y]=av(l[x][y]) elif 'STD' in l[x][y]: l[x][y]=st(l[x][y]) l2.append(int(l[x][y])) return sum(l2)/len(l2) def st(j): l1=[] l2=[] l3=[] for k in j: if k.isdigit(): l1.append(k) for x in range(int(l1[0])-1,int(l1[2])): for y in range(int(l1[1])-1,int(l1[3])): if not str(l[x][y]).isdigit(): if 'SUM' in l[x][y]: l[x][y]=su(l[x][y]) elif 'AVG' in l[x][y]: l[x][y]=av(l[x][y]) elif 'STD' in l[x][y]: l[x][y]=st(l[x][y]) l2.append(int(l[x][y])) a=sum(l2)/len(l2) for b in l2: l3.append((b-a)**2) return (sum(l3)/len(l3))**0.5 n,m=map(int,input().split()) l=[list(input().strip().split()) for i in range(n)] for i in l: for j in i: if not str(j).isdigit(): if 'SUM' in j: j=su(j) print(f"{float(j):.2f}",end=' ') elif 'AVG' in j: j=av(j) print(f"{float(j):.2f}",end=' ') elif 'STD' in j: j=st(j) print(f"{float(j):.2f}",end=' ') else: print(f"{float(j):.2f}",end=' ') print()
0.0分
0 人评分
C语言训练-谁家孩子跑最慢* (C语言代码)浏览:1507 |
川哥的吩咐 (C++代码)浏览:1008 |
C语言程序设计教程(第三版)课后习题9.3 (Java代码)浏览:956 |
【密码】 (C语言代码)浏览:333 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:470 |
C语言程序设计教程(第三版)课后习题7.2 (C语言代码)浏览:740 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:681 |
C语言训练-斐波纳契数列 (C语言代码)浏览:503 |
1199题解浏览:653 |
2004年秋浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:595 |