鱼C论坛

 找回密码
 立即注册
楼主: 欧拉计划

题目11:在20×20的网格中同一直线上四个数的最大乘积是多少?

[复制链接]
发表于 2017-8-10 10:40:59 | 显示全部楼层
grid = '''08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08
49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00
81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65
52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91
22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80
24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50
32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70
67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21
24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72
21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95
78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92
16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57
86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58
19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40
04 52 08 83 97 35 99 16 07 97 57 32 16 26 26 79 33 27 98 66
88 36 68 87 57 62 20 72 03 46 33 67 46 55 12 32 63 93 53 69
04 42 16 73 38 25 39 11 24 94 72 18 08 46 29 32 40 62 76 36
20 69 36 41 72 30 23 88 34 62 99 69 82 67 59 85 74 04 36 16
20 73 35 29 78 31 90 01 74 31 49 71 48 86 81 16 23 57 05 54
01 70 54 71 83 51 54 69 16 92 33 48 61 43 52 01 89 19 67 48'''

a = grid.split('\n')
a = [[int(j) for j in i.split()] for i in a]

rs = []

for i in range(20):
    for j in range(20):
        if i+3 < 20:
            rs.append(a[i][j]*a[i+1][j]*a[i+2][j]*a[i+3][j])
        if j+3 < 20:
            rs.append(a[i][j]*a[i][j+1]*a[i][j+2]*a[i][j+3])
        if i+3 < 20 and j+3 < 20:
            rs.append(a[i][j]*a[i+1][j+1]*a[i+2][j+2]*a[i+3][j+3])
        if i+3 < 20 and j-3 >= 0:
            rs.append(a[i][j]*a[i+1][j-1]*a[i+2][j-2]*a[i+3][j-3])
print(max(rs))

70600674
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-3-21 20:16:34 | 显示全部楼层
#include <stdio.h>
#include<time.h>
int Horizontal(int num[20][20])
{
        int i,j,m,max=0;
        for(i=0;i<20;i++)
        {
                for(j=0;j<17;j++)
                {
                        m=num[i][j]*num[i][j+1]*num[i][j+2]*num[i][j+3];
                        if(m>max)
                        {
                                max=m;
                        }
                }
        }
        return max;
}
int Vertical(int num[][20])
{
                int j,i,m,max=0;
                for(j=0;j<20;j++)
                {
                        for(i=0;i<17;i++)
                        {
                                m=num[i][j]*num[i+1][j]*num[i+2][j]*num[i+3][j];
                                if(m>max)
                                {
                                        max=m;
                                }
                        }
                }
                return max;
}
int LeadingDiagonal(int num[][20])
{
        int i,j,m,max=0;
        for(i=0;i<17;i++)
        {
                for(j=0;j<17;j++)
                {
                        m=num[i][j]*num[i+1][j+1]*num[i+2][j+2]*num[i+3][j+3];
                        if(m>max)
                        {
                                max=m;
                        }
                }
        }
        return max;
}
int AccessoryDiagonal(int num[][20])
{
        int i,j,m,max=0;
        for(i=3;i<20;i++)
        {
                for(j=0;j<17;j++)
                {
                        m=num[i][j]*num[i-1][j+1]*num[i-2][j+2]*num[i-3][j+3];
                        if(m>max)
                        {
                                max=m;
                        }
                }
        }
        return max;
}

int main()
{
        clock_t start,end;
        int i;
    int num[20][20] = {
                        { 8, 2,22,97,38,15, 0,40, 0,75, 4, 5, 7,78,52,12,50,77,91, 8},
                        {49,49,99,40,17,81,18,57,60,87,17,40,98,43,69,48, 4,56,62, 0},
                        {81,49,31,73,55,79,14,29,93,71,40,67,53,88,30, 3,49,13,36,65},
                        {52,70,95,23, 4,60,11,42,69,24,68,56, 1,32,56,71,37, 2,36,91},
                        {22,31,16,71,51,67,63,89,41,92,36,54,22,40,40,28,66,33,13,80},
                        {24,47,32,60,99, 3,45, 2,44,75,33,53,78,36,84,20,35,17,12,50},
                        {32,98,81,28,64,23,67,10,26,38,40,67,59,54,70,66,18,38,64,70},
                        {67,26,20,68, 2,62,12,20,95,63,94,39,63, 8,40,91,66,49,94,21},
                        {24,55,58, 5,66,73,99,26,97,17,78,78,96,83,14,88,34,89,63,72},
                        {21,36,23, 9,75, 0,76,44,20,45,35,14, 0,61,33,97,34,31,33,95},
                        {78,17,53,28,22,75,31,67,15,94, 3,80, 4,62,16,14, 9,53,56,92},
                        {16,39, 5,42,96,35,31,47,55,58,88,24, 0,17,54,24,36,29,85,57},
                        {86,56, 0,48,35,71,89, 7, 5,44,44,37,44,60,21,58,51,54,17,58},
                        {19,80,81,68, 5,94,47,69,28,73,92,13,86,52,17,77, 4,89,55,40},
                        { 4,52, 8,83,97,35,99,16, 7,97,57,32,16,26,26,79,33,27,98,66},
                        {88,36,68,87,57,62,20,72, 3,46,33,67,46,55,12,32,63,93,53,69},
                        { 4,42,16,73,38,25,39,11,24,94,72,18, 8,46,29,32,40,62,76,36},
                        {20,69,36,41,72,30,23,88,34,62,99,69,82,67,59,85,74, 4,36,16},
                        {20,73,35,29,78,31,90, 1,74,31,49,71,48,86,81,16,23,57, 5,54},
                        { 1,70,54,71,83,51,54,69,16,92,33,48,61,43,52, 1,89,19,67,48}
                     };
        int max[5]={0};
        start=clock();
        max[1]=Horizontal(num);
        printf("横向的最大值为%d\n",max[1]);
        max[2]=Vertical(num);
        printf("竖向的最大值为%d\n",max[2]);
        max[3]=LeadingDiagonal(num);
        printf("主对角线方向的最大值为%d\n",max[3]);
        max[4]=AccessoryDiagonal(num);
        printf("副对角线方向的最大值为%d\n",max[4]);
        for(i=1;i<5;i++)
        {
                if(max[i]>max[0])
                {
                        max[0]=max[i];
                }
        }
        printf("整体的最大值为%d\n",max[0]);
        end=clock();
        printf("一共用时%f秒\n",(double)(end-start)/CLK_TCK);
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-2 19:05:25 | 显示全部楼层
import time


start = time.time()
data = '''08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08
49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00
81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65
52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91
22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80
24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50
32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70
67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21
24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72
21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95
78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92
16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57
86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58
19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40
04 52 08 83 97 35 99 16 07 97 57 32 16 26 26 79 33 27 98 66
88 36 68 87 57 62 20 72 03 46 33 67 46 55 12 32 63 93 53 69
04 42 16 73 38 25 39 11 24 94 72 18 08 46 29 32 40 62 76 36
20 69 36 41 72 30 23 88 34 62 99 69 82 67 59 85 74 04 36 16
20 73 35 29 78 31 90 01 74 31 49 71 48 86 81 16 23 57 05 54
01 70 54 71 83 51 54 69 16 92 33 48 61 43 52 01 89 19 67 48
'''


def lineProductMax(numlist):
    maxProduct = 1
    for num in numlist[:4]:
        maxProduct *= num
    for i in range(1, len(numlist) - 3):
        maxProduct = max(numlist[i] * numlist[i + 1] * numlist[i + 2] * numlist[i + 3], maxProduct)
    return maxProduct
result = 0
for linenumer in range(20):
    linelist = [int(data[k: k+2]) for k in range(60 * linenumer, 60 * linenumer + 60, 3)]
    result = max(result, lineProductMax(linelist))
for colnumer in range(20):
    collist = [int(data[k: k+2]) for k in range(colnumer * 3, 60 * 20, 60)]
    result = max(result, lineProductMax(collist))
for leftupdiag in range(4, 21):
    leftlist = [int(data[k: k+2]) for k in range(leftupdiag * 3, 60 * leftupdiag, 60 - 3)]
    result = max(result, lineProductMax(leftlist))
for leftdowndiag in range(2, 18):
    leftdownlist = [int(data[k: k+2]) for k in range(leftdowndiag * 60, 60 * 20, 60 - 3)]
    result = max(result, lineProductMax(leftdownlist))
for rightupdiag in range(17):
    rightuplist = [int(data[k: k+2]) for k in range(rightupdiag * 3, 60 * 20, 60 + 3)]
    result = max(result, lineProductMax(rightuplist))
for rightdowndiag in range(2, 18):
    rightdownlist = [int(data[k: k+2]) for k in range(rightdowndiag * 60, 60 * 20, 60 + 3)]
    result = max(result, lineProductMax(rightdownlist))
print result
print time.time() - start
==================
python
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

匿名鱼油  发表于 2018-5-5 03:31:02
Fantastic goods from you, man. I've take into account your stuff prior to and you are simply too fantastic. I really like what you have got here, certainly like what you're stating and the way in which you say it. You are making it enjoyable and you continue to care for to stay it sensible. I can not wait to learn much more from you. This is really a wonderful website.
Fitflops Sale Clearance UK http://www.fitflopssaleclearanceuk.com
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具

匿名鱼油  发表于 2018-5-7 03:39:43
I am really inspired along with your writing skills and also with the format for your blog. Is that this a paid topic or did you modify it yourself? Either way keep up the nice high quality writing, it rare to peer a great blog like this one nowadays..
Fitflops Sale http://www.fitflopssaleclearanceuk.com
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具

发表于 2018-8-27 10:22:16 | 显示全部楼层
a='''08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08
49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00
81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65
52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91
22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80
24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50
32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70
67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21
24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72
21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95
78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92
16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57
86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58
19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40
04 52 08 83 97 35 99 16 07 97 57 32 16 26 26 79 33 27 98 66
88 36 68 87 57 62 20 72 03 46 33 67 46 55 12 32 63 93 53 69
04 42 16 73 38 25 39 11 24 94 72 18 08 46 29 32 40 62 76 36
20 69 36 41 72 30 23 88 34 62 99 69 82 67 59 85 74 04 36 16
20 73 35 29 78 31 90 01 74 31 49 71 48 86 81 16 23 57 05 54
01 70 54 71 83 51 54 69 16 92 33 48 61 43 52 01 89 19 67 48'''
c=list(map(int,a.split()))
d=[c[i*20:i*20+20] for i in range(20)]
L=[[(0,0),(0,1),(0,2),(0,3)],
   [(0,0),(1,1),(2,2),(3,3)],
   [(0,0),(1,0),(2,0),(3,0)],
   [(0,0),(1,-1),(2,-2),(3,-3)]]
def fun(i,j,k):
    t=[d[i+each[0]][j+each[1]] for each in L[k]]
    if 0 in t:
       return 0
    else:
        return eval('*'.join(list(map(str,t))))
m=0
for i in range(20):
    for j in range(20):
        e,f,g,h=0,0,0,0
        if j<17:
            e=fun(i,j,0)
            if i<17:
                f=fun(i,j,1)
        if i<17:
            g=fun(i,j,2)
            if j>2:
                h=fun(i,j,3)
        m=max(m,e,f,g,h)
print(m)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-12-6 20:29:23 | 显示全部楼层
本帖最后由 Wave.LT 于 2018-12-6 20:34 编辑
tic
clear all;
clc;
A=[08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08
49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00
81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65
52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91
22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80
24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50
32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70
67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21
24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72
21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95
78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92
16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57
86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58
19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40
04 52 08 83 97 35 99 16 07 97 57 32 16 26 26 79 33 27 98 66
88 36 68 87 57 62 20 72 03 46 33 67 46 55 12 32 63 93 53 69
04 42 16 73 38 25 39 11 24 94 72 18 08 46 29 32 40 62 76 36
20 69 36 41 72 30 23 88 34 62 99 69 82 67 59 85 74 04 36 16
20 73 35 29 78 31 90 01 74 31 49 71 48 86 81 16 23 57 05 54
01 70 54 71 83 51 54 69 16 92 33 48 61 43 52 01 89 19 67 48];
B=zeros(20,17);
C=zeros(17,20);
for t=1:20
    for k=1:17
        B(t,k)=A(t,k)*A(t,k+1)*A(t,k+2)*A(t,k+3);
        C(k,t)=A(k,t)*A(k+1,t)*A(k+2,t)*A(k+3,t);
    end
    
end
D=zeros(20,20);
for i=1:20
    D(:,21-i)=A(:,i);
end
c=1;
for j=-16:16
    G=diag(D,j);
    E=diag(A,j);
    a=20-abs(j);
    for b=1:a-3;
        F(1,c)=E(b)*E(b+1)*E(b+2)*E(b+3);
        H(1,c)=G(b)*G(b+1)*G(b+2)*G(b+3);
        c=c+1;
    end
end
d=max(max(B));
e=max(max(C));
f=max(F);
h=max(H);
I=[d e f h];
s=max(I);
disp(['the greatest product of four adjacent numbers in the same direction (up, down, left, right, or diagonally) in the 20×20 grid is ',num2str(s)]);
toc
the greatest product of four adjacent numbers in the same direction (up, down, left, right, or diagonally) in the 20×20 grid is 70600674
Elapsed time is 0.018345 seconds.

效率比起各位大佬的有点低,matilab写的,才开始学。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-12-9 18:29:02 | 显示全部楼层
70600674
s = '''
08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08
49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00
81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65
52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91
22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80
24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50
32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70
67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21
24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72
21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95
78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92
16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57
86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58
19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40
04 52 08 83 97 35 99 16 07 97 57 32 16 26 26 79 33 27 98 66
88 36 68 87 57 62 20 72 03 46 33 67 46 55 12 32 63 93 53 69
04 42 16 73 38 25 39 11 24 94 72 18 08 46 29 32 40 62 76 36
20 69 36 41 72 30 23 88 34 62 99 69 82 67 59 85 74 04 36 16
20 73 35 29 78 31 90 01 74 31 49 71 48 86 81 16 23 57 05 54
01 70 54 71 83 51 54 69 16 92 33 48 61 43 52 01 89 19 67 48
'''
import re
def getEle(s):
        num = []
        for i in s.split("\n"):
                # print(i)
                j = []
                if i:
                        # for e in re.findall(r'(\d{2})\s',i):  会出现不可预知的错误:
                        # 比如第一行 08 会在 for 循环导出时 丢失,此外每一行都会出现一个数字的丢失
                        # 原本每一行有 20 个数字,在for循环后就变为19个 
                        # 但是 使用 re.sub 方法却不会出现这种情况 
                        # for e in re.sub(r'[^\d]',' ',i).split():
                        # 另外 str.split() 默认为 以空格作为分隔符,也就是说不论多少空格都会分隔,
                        # 而 当指定以空格个数时,作为分隔符分割的空格数就是指定的空格数: str.split(" ") # 以一个空格分隔
                        for e in i.split():
                                j.append(int(e))
                        num.append(j)
        return num

def main(s):
        num = getEle(s)
        q1 = []
        j = len(num) - 3
        print(len(num))
        # i增加 为竖向移动
        for i in range(0,j):
                print(num[i])
                # k增加 为横向移动
                j2 = len(num[i]) - 3
                print(len(num[i]))
                for k in range(0,j2):
                        # 计算左边
                        a = num[i][k] * num[i+1][k] * num[i+2][k] * num[i+3][k]
                        # 计算上边
                        b = num[i][k] * num[i][k+1] * num[i][k+2] * num[i][k+3]
                        # 计算左下到右上斜边
                        c = num[i][k+3] * num[i+1][k+2] * num[i+2][k+1] * num[i+3][k]
                        # 计算左上到右下斜边
                        d = num[i][k] * num[i+1][k+1] * num[i+2][k+2] * num[i+3][k+3]
                        q1.append(max([a,b,c,d]))
        # 计算没覆盖到de三条右竖边 和 三条下底横边
                # 竖边
                e1 = num[i][19] * num[i+1][19] * num[i+2][19] * num[i+3][19]
                e2 = num[i][18] * num[i+1][18] * num[i+2][18] * num[i+3][18]
                e3 = num[i][17] * num[i+1][17] * num[i+2][17] * num[i+3][17]
                q1.append(max([e1,e2,e3]))
        t1 = max(q1)
        # 横边
        q2 = []
        for i in range(17,20):
                for k in range(0,17):
                        f1 = num[i][k] * num[i][k+1] * num[i][k+2] * num[i][k+3]
                        q2.append(f1)
        t2 = max(q2)
        return max([t1,t2])


if __name__ == "__main__":
        print(main(s))
                
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-3-23 22:31:39 | 显示全部楼层
numArrStr = '''08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08
49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00
81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65
52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91
22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80
24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50
32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70
67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21
24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72
21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95
78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92
16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57
86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58
19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40
04 52 08 83 97 35 99 16 07 97 57 32 16 26 26 79 33 27 98 66
88 36 68 87 57 62 20 72 03 46 33 67 46 55 12 32 63 93 53 69
04 42 16 73 38 25 39 11 24 94 72 18 08 46 29 32 40 62 76 36
20 69 36 41 72 30 23 88 34 62 99 69 82 67 59 85 74 04 36 16
20 73 35 29 78 31 90 01 74 31 49 71 48 86 81 16 23 57 05 54
01 70 54 71 83 51 54 69 16 92 33 48 61 43 52 01 89 19 67 48'''

list1 = numArrStr.split("\n")
list2 = []
for i in range(20):
    list2.append(list1[i].split(" "))
for i in range(20):
    for j in range(20):
        list2[i][j] = int(list2[i][j])
list3 = list2
list_max = []

#求横向最大
list_horizontal = []
for i in range(20):
    index = 0
    while index <= 16:
        product = 1
        for j in range(index, index + 4):
            product *= list3[i][j]
        list_horizontal.append(product)
        index += 1
list_horizontal.sort()
list_max.append(list_horizontal[-1])

#求纵向最大
list_vertical = []
for i in range(20):
    index = 0
    while index <= 16:
        product = 1
        for j in range(index, index + 4):
            product *= list3[j][i]
        list_vertical.append(product)
        index += 1
list_vertical.sort()
list_max.append(list_vertical[-1])

#求对角线最大
#1、从左上至右下方向(包括主对角线),且为右上半区:
list_diagonal1 = []
for i in range(17):
    for j in range(17-i):
        product = 1
        for k in range(4):
            product *= list3[j+k][i+j+k]
        list_diagonal1.append(product)
list_diagonal1.sort()
list_max.append(list_diagonal1[-1])

#2、从左上至右下方向(包括主对角线),且为左半区:
list_diagonal2 = []
for i in range(17):
    for j in range(17-i):
        product = 1
        for k in range(4):
            product *= list3[i+j+k][j+k]
        list_diagonal2.append(product)
list_diagonal2.sort()
list_max.append(list_diagonal2[-1])

#3、从右上至左下方向(包括主对角线),且为左上半区:
list_diagonal3 = []
for i in range(19, 2, -1):
    for j in range(i-2):
        product = 1
        for k in range(4):
            product *= list3[j+k][i-j-k]
        list_diagonal3.append(product)
list_diagonal3.sort()
list_max.append(list_diagonal3[-1])

#4、从右上至左下方向(包括主对角线),且为右下半区:
list_diagonal4 = []
for i in range(19, 2, -1):
    for j in range(i-2):
        product = 1
        for k in range(4):
            product *= list3[19-i+j+k][19-j-k]
        list_diagonal4.append(product)
list_diagonal4.sort()
list_max.append(list_diagonal4[-1])

#将以上得到的最大值进行排序:
list_max.sort()
print(list_max[-1])
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-4-25 13:23:15 | 显示全部楼层
import time
import math
import functools

def test1():
    dict1 = {}
    result = 0
    
    
    with open(r'C:\Users\小华仔\Desktop\test\test1.txt') as f:
        for m in range(20):
            li = f.readline().split()
            for n in range(20):
                value = li[n]
                key = '+'.join([str(m),str(n)])
                dict1[key] = value

    #横向遍历
    for m in range(20):   #控制行
        for n in range(17):   #控制列
            count = 0
            temp = 1
            while count <=3:
                key = '+'.join([str(m),str(n+count)])
                temp *= int(dict1[key])
                count += 1
            if result < temp:
                result = temp
                num = [dict1['+'.join([str(m),str(n)])],dict1['+'.join([str(m),str(n+1)])],dict1['+'.join([str(m),str(n+2)])],dict1['+'.join([str(m),str(n+3)])]]
                local = []
                local.append('行'.join([str(m),str(n)]))
                local.append('行'.join([str(m),str(n+1)]))
                local.append('行'.join([str(m),str(n+2)]))
                local.append('行'.join([str(m),str(n+3)]))

    #纵向遍历
    for n in range(20):   #控制列
        for m in range(17):   #控制行
            count = 0
            temp = 1
            while count <=3:
                key = '+'.join([str(m+count),str(n)])
                temp *= int(dict1[key])
                count += 1
            if result < temp:
                result = temp
                num = [dict1['+'.join([str(m),str(n)])],dict1['+'.join([str(m+1),str(n)])],dict1['+'.join([str(m+2),str(n)])],dict1['+'.join([str(m+3),str(n)])]]
                local = []
                local.append('行'.join([str(m),str(n)]))
                local.append('行'.join([str(m+1),str(n)]))
                local.append('行'.join([str(m+2),str(n)]))
                local.append('行'.join([str(m+3),str(n)]))

    #/向遍历上半区(包括中线)
    for i in range(3,20):    #控制列移动从0行3列开始向右移动
        n = i
        li = []
        m = 0
        key = '+'.join([str(m),str(n)])
        li.append(int(dict1[key]))
        while True:
            if len(li) == 4:
                temp = functools.reduce(lambda x, y: x*y, li)
                if result < temp:
                    result = temp
                    num = [dict1['+'.join([str(m),str(n)])],dict1['+'.join([str(m-1),str(n+1)])],dict1['+'.join([str(m-2),str(n+2)])],dict1['+'.join([str(m-3),str(n+3)])]]
                    local = []
                    local.append('行'.join([str(m),str(n)]))
                    local.append('行'.join([str(m-1),str(n+1)]))
                    local.append('行'.join([str(m-2),str(n+2)]))
                    local.append('行'.join([str(m-3),str(n+3)]))
                li.pop(0)
            else:
                m += 1
                n -= 1
                if n < 0:
                    break
                key = '+'.join([str(m),str(n)])
                li.append(int(dict1[key]))
                
    #/向遍历下半区(不包括中线)
    for i in range(1,17):    #控制列移动从19行1列开始向右移动
        n = i
        li = []
        m = 19
        key = '+'.join([str(m),str(n)])
        li.append(int(dict1[key]))
        while True:
            if len(li) == 4:
                temp = functools.reduce(lambda x, y: x*y, li)
                if result < temp:
                    result = temp
                    num = [dict1['+'.join([str(m),str(n)])],dict1['+'.join([str(m+1),str(n-1)])],dict1['+'.join([str(m+2),str(n-2)])],dict1['+'.join([str(m+3),str(n-3)])]]
                    local = []
                    local.append('行'.join([str(m),str(n)]))
                    local.append('行'.join([str(m+1),str(n-1)]))
                    local.append('行'.join([str(m+2),str(n-2)]))
                    local.append('行'.join([str(m+3),str(n-3)]))
                li.pop(0)
            else:
                m -= 1
                n += 1
                if n > 19:
                    break
                key = '+'.join([str(m),str(n)])
                li.append(int(dict1[key]))

    #\向遍历上半区(包括中线)
    for i in range(0,17):    #控制列移动从0行0列开始向右移动
        n = i
        li = []
        m = 0
        key = '+'.join([str(m),str(n)])
        li.append(int(dict1[key]))
        while True:
            if len(li) == 4:
                temp = functools.reduce(lambda x, y: x*y, li)
                if result < temp:
                    result = temp
                    num = [dict1['+'.join([str(m),str(n)])],dict1['+'.join([str(m-1),str(n-1)])],dict1['+'.join([str(m-2),str(n-2)])],dict1['+'.join([str(m-3),str(n-3)])]]
                    local = []
                    local.append('行'.join([str(m),str(n)]))
                    local.append('行'.join([str(m-1),str(n-1)]))
                    local.append('行'.join([str(m-2),str(n-2)]))
                    local.append('行'.join([str(m-3),str(n-3)]))
                li.pop(0)
            else:
                m += 1
                n += 1
                if n > 19:
                    break
                key = '+'.join([str(m),str(n)])
                li.append(int(dict1[key]))

    #\向遍历下半区(不包括中线)
    for i in range(3,19):    #控制列移动从19行3列开始向右移动
        n = i
        li = []
        m = 19
        key = '+'.join([str(m),str(n)])
        li.append(int(dict1[key]))
        while True:
            if len(li) == 4:
                temp = functools.reduce(lambda x, y: x*y, li)
                if result < temp:
                    result = temp
                    num = [dict1['+'.join([str(m),str(n)])],dict1['+'.join([str(m+1),str(n+1)])],dict1['+'.join([str(m+2),str(n+2)])],dict1['+'.join([str(m+3),str(n+3)])]]
                    local = []
                    local.append('行'.join([str(m),str(n)]))
                    local.append('行'.join([str(m+1),str(n+1)]))
                    local.append('行'.join([str(m+2),str(n+2)]))
                    local.append('行'.join([str(m+3),str(n+3)]))
                li.pop(0)
            else:
                m -= 1
                n -= 1
                if n < 0:
                    break
                key = '+'.join([str(m),str(n)])
                li.append(int(dict1[key]))

    
    return local,num,result


                        
        


start = time.perf_counter()

print(test1())
end = time.perf_counter()
print(end-start)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-3 15:20:45 | 显示全部楼层
#在20×20的网格中同一直线上四个数的最大乘积是多少?

import time
start=time.clock()
a="""08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08
49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00
81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65
52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91
22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80
24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50
32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70
67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21
24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72
21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95
78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92
16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57
86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58
19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40
04 52 08 83 97 35 99 16 07 97 57 32 16 26 26 79 33 27 98 66
88 36 68 87 57 62 20 72 03 46 33 67 46 55 12 32 63 93 53 69
04 42 16 73 38 25 39 11 24 94 72 18 08 46 29 32 40 62 76 36
20 69 36 41 72 30 23 88 34 62 99 69 82 67 59 85 74 04 36 16
20 73 35 29 78 31 90 01 74 31 49 71 48 86 81 16 23 57 05 54
01 70 54 71 83 51 54 69 16 92 33 48 61 43 52 01 89 19 67 48"""
b=a.split("\n")
x=[]
y=[]
z=[]
for i in range(0,20):
    x.append(b[i].split(" "))

for i in range(0,20):
    for j in range(0,17):
        y=[int(x[i][j]),int(x[i][j+1]),int(x[i][j+2]),int(x[i][j+3])]
        z.append(y[0]*y[1]*y[2]*y[3])

for i in range(0,17):
    for j in range(0,20):
        y=[int(x[i][j]),int(x[i+1][j]),int(x[i+2][j]),int(x[i+3][j])]
        z.append(y[0]*y[1]*y[2]*y[3])

for i in range(0,17):
    for j in range(0,17):
        y=[int(x[i][j]),int(x[i+1][j+1]),int(x[i+2][j+2]),int(x[i+3][j+3])]
        z.append(y[0]*y[1]*y[2]*y[3])

for i in range(0,17):
    for j in range(3,20):
        y=[int(x[i][j]),int(x[i+1][j-1]),int(x[i+2][j-2]),int(x[i+3][j-3])]
        z.append(y[0]*y[1]*y[2]*y[3])
result=max(z)
print(result)
end=time.clock()
print("花费时间:%fs"%(end-start))

70600674
花费时间:0.015631s
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-29 19:10:29 | 显示全部楼层
本帖最后由 成为极客 于 2019-5-29 19:11 编辑
list1 = [[8,2,22,97,38,15,0,40,0,75,4,5,7,78,52,12,50,77,91,8],
        [49,49,99,40,17,81,18,57,60,87,17,40,98,43,69,48,4,56,62,0],
        [81,49,31,73,55,79,14,29,93,71,40,67,53,88,30,3,49,13,36,65],
        [52,70,95,23,4,60,11,42,69,24,68,56,1,32,56,71,37,2,36,91],
        [22,31,16,71,51,67,63,89,41,92,36,54,22,40,40,28,66,33,13,80],
        [24,47,32,60,99,3,45,2,44,75,33,53,78,36,84,20,35,17,12,50],
        [32,98,81,28,64,23,67,10,26,38,40,67,59,54,70,66,18,38,64,70],
       [67,26,20,68,2,62,12,20,95,63,94,39,63,8,40,91,66,49,94,21],
        [24,55,58,5,66,73,99,26,97,17,78,78,96,83,14,88,34,89,63,72],
        [21,36,23,9,75,0,76,44,20,45,35,14,0,61,33,97,34,31,33,95],
        [78,17,53,28,22,75,31,67,15,94,3,80,4,62,16,14,9,53,56,92],
        [16,39,5,42,96,35,31,47,55,58,88,24,0,17,54,24,36,29,85,57],
        [86,56,0,48,35,71,89,7,5,44,44,37,44,60,21,58,51,54,17,58],
        [19,80,81,68,5,94,47,69,28,73,92,13,86,52,17,77,4,89,55,40],
        [4,52,8,83,97,35,99,16,7,97,57,32,16,26,26,79,33,27,98,66],
        [88,36,68,87,57,62,20,72,3,46,33,67,46,55,12,32,63,93,53,69],
        [4,42,16,73,38,25,39,11,24,94,72,18,8,46,29,32,40,62,76,36],
        [20,69,36,41,72,30,23,88,34,62,99,69,82,67,59,85,74,4,36,16],
        [20,73,35,29,78,31,90,1,74,31,49,71,48,86,81,16,23,57,5,54],
        [1,70,54,71,83,51,54,69,16,92,33,48,61,43,52,1,89,19,67,48]]
maximum = 0
#计算竖排
for i in range(17):
    for j in range(20):
        num = list1[i][j]*list1[i+1][j]*list1[i+2][j]*list1[i+3][j]
        if num >maximum:
            maximum = num
#计算横排
for i in range(20):
    for j in range(17):
        num = list1[i][j]*list1[i][j+1]*list1[i][j+2]*list1[i][j+3]
        if num >maximum:
            maximum = num
#计算左斜
for i in range(17):
    for j in range(17):
        num = list1[i][j]*list1[i+1][j+1]*list1[i+2][j+2]*list1[i+3][j+3]
        if num >maximum:
            maximum = num
#计算右斜
for i in range(17):
    for j in range(3,20):
        num = list1[i][j]*list1[i+1][j-1]*list1[i+2][j-2]*list1[i+3][j-3]
        if num >maximum:
            maximum = num
print(maximum)
70600674
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-8-3 19:24:31 | 显示全部楼层
本帖最后由 永恒的蓝色梦想 于 2021-3-6 22:25 编辑
data = [[int(j) for j in i.split(' ')] for i in '''08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08
49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00
81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65
52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91
22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80
24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50
32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70
67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21
24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72
21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95
78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92
16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57
86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58
19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40
04 52 08 83 97 35 99 16 07 97 57 32 16 26 26 79 33 27 98 66
88 36 68 87 57 62 20 72 03 46 33 67 46 55 12 32 63 93 53 69
04 42 16 73 38 25 39 11 24 94 72 18 08 46 29 32 40 62 76 36
20 69 36 41 72 30 23 88 34 62 99 69 82 67 59 85 74 04 36 16
20 73 35 29 78 31 90 01 74 31 49 71 48 86 81 16 23 57 05 54
01 70 54 71 83 51 54 69 16 92 33 48 61 43 52 01 89 19 67 48'''.split('\n')]
result = 0
range17 = range(17)

for l in data:
  for i in range17:
    result = max(result, l[i] * l[i + 1] * l[i + 2] * l[i + 3])

for j in range(20):
  for i in range17:
    result = max(result, data[i][j] * data[i + 1][j], data[i + 2][j] * data[i + 3][j])

for i in range17:
  for j in range17:
    result = max(result, data[i][j] * data[i + 1][j + 1] * data[i + 2][j + 2] * data[i + 3][j + 3])

for i in range17:
  for j in range17:
    result = max(result, data[i][j + 3] * data[i + 1][j + 2] * data[i + 2][j + 1] * data[i + 3][j])

print(result)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-1-3 12:50:57 | 显示全部楼层
#include <stdio.h>
#include <stdlib.h>
#include "string.h"
int IsMaxResult(int (*array)[20],int *a1, int *a2, int *a3, int *a4){
    //横向判断
    int result = 0; 
    for(int j = 0; j<20; j++){
        for(int i = 0; i<20; i++){
            if(i>16){
                break;
            }
            int temp = array[j][i]*array[j][i+1]*array[j][i+2]*array[j][i+3];
            if(temp > result){
                result = temp;
                *a1 = array[j][i];
                *a2 = array[j][i+1];
                *a3 = array[j][i+2];
                *a4 = array[j][i+3];
            }
        }
    }
    //纵向判断
    for(int i  = 0; i<20; i++){
        for(int j = 0; j<20; j++){
            if(i >16){
                break;
            }
            int temp = array[i][j]*array[i+1][j]*array[i+2][j]*array[i+3][j];
            if(temp > result){
                result = temp;
                *a1 = array[i][j];
                *a2 = array[i+1][j];
                *a3 = array[i+2][j];
                *a4 = array[i+3][j];
            }
        }
    }
    //对角线方向:左斜线
    for(int i = 0; i<20; i++){
        for(int j = 0 ; j<20;j++){
            if(i>16 || j>16){
                break;
            }
            int temp = array[i][j]*array[i+1][j+1]*array[i+2][j+2]*array[i+3][j+3];
            if(temp > result){
                result = temp;
                *a1 = array[i][j];
                *a2 = array[i+1][j+1];
                *a3 = array[i+2][j+2];
                *a4 = array[i+3][j+3];
            }
        }
    }
    //对角线方向:右斜线
    for(int i = 19; i>= 0;i--){
        for(int j = 19; j>= 0; j--){
            if(i<3 ||j<3){
                break;
            }
            int temp = array[i][j]*array[i-1][j-1]*array[i-2][j-2]*array[i-3][j-3];
            if(temp > result){
                result = temp;
                *a1 = array[i][j];
                *a2 = array[i-1][j-1];
                *a3 = array[i-2][j-2];
                *a4 = array[i-3][j-3];
            }
        }
    }
    return result;
}
int main(void)
{
        int a[20][20] = 
                        {
                        { 8, 2,22,97,38,15, 0,40, 0,75, 4, 5, 7,78,52,12,50,77,91, 8},
                        {49,49,99,40,17,81,18,57,60,87,17,40,98,43,69,48, 4,56,62, 0},
                        {81,49,31,73,55,79,14,29,93,71,40,67,53,88,30, 3,49,13,36,65},
                        {52,70,95,23, 4,60,11,42,69,24,68,56, 1,32,56,71,37, 2,36,91},
                        {22,31,16,71,51,67,63,89,41,92,36,54,22,40,40,28,66,33,13,80},
                        {24,47,32,60,99, 3,45, 2,44,75,33,53,78,36,84,20,35,17,12,50},
                        {32,98,81,28,64,23,67,10,26,38,40,67,59,54,70,66,18,38,64,70},
                        {67,26,20,68, 2,62,12,20,95,63,94,39,63, 8,40,91,66,49,94,21},
                        {24,55,58, 5,66,73,99,26,97,17,78,78,96,83,14,88,34,89,63,72},
                        {21,36,23, 9,75, 0,76,44,20,45,35,14, 0,61,33,97,34,31,33,95},
                        {78,17,53,28,22,75,31,67,15,94, 3,80, 4,62,16,14, 9,53,56,92},
                        {16,39, 5,42,96,35,31,47,55,58,88,24, 0,17,54,24,36,29,85,57},
                        {86,56, 0,48,35,71,89, 7, 5,44,44,37,44,60,21,58,51,54,17,58},
                        {19,80,81,68, 5,94,47,69,28,73,92,13,86,52,17,77, 4,89,55,40},
                        { 4,52, 8,83,97,35,99,16, 7,97,57,32,16,26,26,79,33,27,98,66},
                        {88,36,68,87,57,62,20,72, 3,46,33,67,46,55,12,32,63,93,53,69},
                        { 4,42,16,73,38,25,39,11,24,94,72,18, 8,46,29,32,40,62,76,36},
                        {20,69,36,41,72,30,23,88,34,62,99,69,82,67,59,85,74, 4,36,16},
                        {20,73,35,29,78,31,90, 1,74,31,49,71,48,86,81,16,23,57, 5,54},
                        { 1,70,54,71,83,51,54,69,16,92,33,48,61,43,52, 1,89,19,67,48}
                     };
        int a1,a2,a3,a4; 
        int num  = IsMaxResult(a,&a1,&a2,&a3,&a4);
        printf("finally result is %d*%d*%d*%d = %d\n",a1,a2,a3,a4,num);
        return 0;
}
结果:66*91*88*97 = 51267216
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-23 18:08:54 | 显示全部楼层
#include<stdio.h>
#include<stdlib.h>


int maxlevel(int a[][20])
{
        int max1 = 0;
        int res1;
        for (int i = 0; i < 20; i++)
        {
                for (int j = 0; j < 17; j++)
                {
                        res1 = a[i][j] * a[i][j + 1] * a[i][j + 2] * a[i][j + 3];
                        if (res1 > max1)
                        {
                                max1 = res1;
                        }
                }
                       
        }
        return max1;
}


int maxline(int a[][20])
{
        int max2 = 0;
        int res2;
        for (int i = 0; i < 20; i++)
        {
                for (int j = 0; j < 17; j++)
                {
                        res2 = a[j][i] * a[j+1][i] * a[j+2][i] * a[j+3][i];
                        if (res2 > max2)
                        {
                                max2 = res2;
                        }
                }
               
        }
        return max2;
}

int maxslash(int a[][20])
{
        int max3 = 0;
        int res3;
        for (int i = 0; i < 17; i++)
        {
                for (int j = 0; j < 17; j++)
                {
                        res3 = a[i][j] * a[i + 1][j + 1] * a[i + 2][j + 2] * a[i + 3][j + 3];
                        if (res3 > max3)
                        {
                                max3 = res3;
                        }
                }
        }
        return max3;
}

int maxbackslash(int a[][20])
{
        int max4 = 0;
        int res4;
        int i, j;
        for ( i = 0; i < 17; i++)
        {
                for ( j = 19; j > 2; j--)
                {
                        res4 = a[i][j] * a[i + 1][j - 1] * a[i + 2][j - 2] * a[i + 3][j - 3];
                        if (res4 > max4)
                        {
                                max4 = res4;
                        }
                }
        }
        return max4;
}


        void main()
        {
                int nums[20][20] = {
                        {8 ,2, 22, 97, 38, 15, 0, 40, 0, 75, 4, 5, 7, 78, 52, 12, 50, 77, 91, 8},
                        {49, 49, 99, 40, 17, 81, 18, 57, 60, 87, 17, 40 ,98, 43, 69, 48, 4, 56, 62, 0},
                        {81, 49, 31, 73, 55, 79, 14, 29, 93, 71, 40, 67, 53, 88, 30, 3, 49, 13, 36, 65},
                        {52, 70, 95, 23, 4, 60, 11, 42, 69, 24, 68, 56, 1, 32, 56, 71, 37, 2, 36, 91},
                        {22, 31, 16, 71, 51, 67, 63, 89, 41, 92, 36, 54, 22, 40, 40, 28, 66, 33, 13, 80},
                        {24, 47, 32, 60, 99, 3, 45, 2, 44, 75, 33, 53, 78, 36, 84, 20, 35, 17, 12, 50},
                        {32, 98, 81, 28, 64, 23, 67, 10, 26, 38, 40, 67, 59, 54, 70, 66, 18, 38, 64, 70},
                        {67, 26, 20, 68, 2, 62, 12, 20, 95, 63, 94, 39, 63, 8, 40, 91, 66, 49, 94, 21},
                        {24, 55, 58, 5, 66, 73, 99, 26, 97, 17, 78, 78, 96, 83, 14, 88, 34, 89, 63, 72},
                        {21, 36, 23, 9, 75, 0, 76, 44, 20, 45, 35, 14, 0, 61, 33, 97, 34, 31, 33, 95},
                        {78, 17, 53, 28, 22, 75, 31, 67, 15, 94, 3, 80, 4, 62, 16, 14, 9, 53, 56, 92},
                        {16, 39, 5, 42, 96, 35, 31, 47, 55, 58, 88, 24, 0, 17, 54, 24, 36, 29, 85, 57},
                        {86, 56, 0, 48, 35, 71, 89, 7, 5, 44, 44, 37, 44, 60, 21, 58, 51, 54, 17, 58},
                        {19, 80, 81, 68, 5, 94, 47, 69, 28, 73, 92, 13, 86, 52, 17, 77, 4, 89, 55, 40},
                        {4, 52, 8, 83, 97, 35, 99, 16, 7, 97, 57, 32, 16, 26, 26, 79, 33, 27, 98, 66},
                        {88, 36, 68, 87, 57, 62, 20, 72, 3, 46, 33, 67, 46, 55, 12, 32, 63, 93, 53, 69},
                        {4, 42, 16, 73, 38, 25, 39, 11, 24, 94, 72, 18, 8, 46, 29, 32, 40, 62, 76, 36},
                        {20, 69, 36, 41, 72, 30, 23, 88, 34, 62, 99, 69, 82, 67, 59, 85, 74, 4, 36, 16},
                        {20, 73, 35, 29, 78, 31, 90, 1, 74, 31, 49, 71, 48, 86, 81, 16, 23, 57, 5, 54},
                        {1, 70, 54, 71, 83, 51, 54, 69, 16, 92, 33, 48, 61, 43, 52, 01, 89, 19, 67, 48}
                };
                int max_level = 0;
                int max_line = 0;
                int max_slash = 0;
                int max_backslash = 0;
                int res_max = 0;
                max_level = maxlevel(nums);
                max_line = maxline(nums);
                max_slash = maxslash(nums);
                max_backslash = maxbackslash(nums);
                printf("行的最大值 = %d\n", max_level);
                printf("列的最大值= %d\n", max_line);
                printf("顺斜线的最大值 = %d\n", max_slash);
                printf("反斜线的最大值 = %d\n", max_backslash);
                if (max_level > res_max)
                        res_max = max_level;
                if (max_line < res_max)
                        res_max = max_line;
                if (max_slash > res_max)
                        res_max = max_slash;
                if (max_backslash > res_max)
                        res_max = max_backslash;
                printf("Largest product in a grid is %d\n", res_max);
                system("pause");
        }
输出结果:
行的最大值 = 48477312
列的最大值= 51267216
顺斜线的最大值 = 40304286
反斜线的最大值 = 70600674
Largest product in a grid is 70600674
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-6 15:29:24 | 显示全部楼层
'''在以下这个 20×20 的网格中,四个处于同一对角线上的相邻数字用红色标了出来:
08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08
49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00
81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65
52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91
22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80
24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50
32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70
67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21
24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72
21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95
78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92
16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57
86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58
19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40
04 52 08 83 97 35 99 16 07 97 57 32 16 26 26 79 33 27 98 66
88 36 68 87 57 62 20 72 03 46 33 67 46 55 12 32 63 93 53 69
04 42 16 73 38 25 39 11 24 94 72 18 08 46 29 32 40 62 76 36
20 69 36 41 72 30 23 88 34 62 99 69 82 67 59 85 74 04 36 16
20 73 35 29 78 31 90 01 74 31 49 71 48 86 81 16 23 57 05 54
01 70 54 71 83 51 54 69 16 92 33 48 61 43 52 01 89 19 67 48
这四个数字的乘积是:26 × 63 × 78 × 14 = 1788696。
在这个 20×20 网格中,处于任何方向上(上,下,左,右或者对角线)的四个相邻数字的乘积的最大值是多少?'''

square = "08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08 \n"\
         "49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00 \n"\
         "81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65 \n"\
         "52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91 \n"\
         "22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80 \n"\
         "24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50 \n"\
         "32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70 \n"\
         "67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21 \n"\
         "24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72 \n"\
         "21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95 \n"\
         "78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92 \n"\
         "16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57 \n"\
         "86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58 \n"\
         "19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40 \n"\
         "04 52 08 83 97 35 99 16 07 97 57 32 16 26 26 79 33 27 98 66 \n"\
         "88 36 68 87 57 62 20 72 03 46 33 67 46 55 12 32 63 93 53 69 \n"\
         "04 42 16 73 38 25 39 11 24 94 72 18 08 46 29 32 40 62 76 36 \n"\
         "20 69 36 41 72 30 23 88 34 62 99 69 82 67 59 85 74 04 36 16 \n"\
         "20 73 35 29 78 31 90 01 74 31 49 71 48 86 81 16 23 57 05 54 \n"\
         "01 70 54 71 83 51 54 69 16 92 33 48 61 43 52 01 89 19 67 48 "

def findmax():
    # 创建矩阵
    numsquare = [[8, 2, 22, 97, 38, 15, 0, 40, 0, 75, 4, 5, 7, 78, 52, 12, 50, 77, 91, 8],
                 [49, 49, 99, 40, 17, 81, 18, 57, 60, 87, 17, 40, 98, 43, 69, 48, 4, 56, 62, 0],
                 [81, 49, 31, 73, 55, 79, 14, 29, 93, 71, 40, 67, 53, 88, 30, 3, 49, 13, 36, 65],
                 [52, 70, 95, 23, 4, 60, 11, 42, 69, 24, 68, 56, 1, 32, 56, 71, 37, 2, 36, 91],
                 [22, 31, 16, 71, 51, 67, 63, 89, 41, 92, 36, 54, 22, 40, 40, 28, 66, 33, 13, 80],
                 [24, 47, 32, 60, 99, 3, 45, 2, 44, 75, 33, 53, 78, 36, 84, 20, 35, 17, 12, 50],
                 [32, 98, 81, 28, 64, 23, 67, 10, 26, 38, 40, 67, 59, 54, 70, 66, 18, 38, 64, 70],
                 [67, 26, 20, 68, 2, 62, 12, 20, 95, 63, 94, 39, 63, 8, 40, 91, 66, 49, 94, 21],
                 [24, 55, 58, 5, 66, 73, 99, 26, 97, 17, 78, 78, 96, 83, 14, 88, 34, 89, 63, 72],
                 [21, 36, 23, 9, 75, 0, 76, 44, 20, 45, 35, 14, 0, 61, 33, 97, 34, 31, 33, 95],
                 [78, 17, 53, 28, 22, 75, 31, 67, 15, 94, 3, 80, 4, 62, 16, 14, 9, 53, 56, 92],
                 [16, 39, 5, 42, 96, 35, 31, 47, 55, 58, 88, 24, 0, 17, 54, 24, 36, 29, 85, 57],
                 [86, 56, 0, 48, 35, 71, 89, 7, 5, 44, 44, 37, 44, 60, 21, 58, 51, 54, 17, 58],
                 [19, 80, 81, 68, 5, 94, 47, 69, 28, 73, 92, 13, 86, 52, 17, 77, 4, 89, 55, 40],
                 [4, 52, 8, 83, 97, 35, 99, 16, 7, 97, 57, 32, 16, 26, 26, 79, 33, 27, 98, 66],
                 [88, 36, 68, 87, 57, 62, 20, 72, 3, 46, 33, 67, 46, 55, 12, 32, 63, 93, 53, 69],
                 [4, 42, 16, 73, 38, 25, 39, 11, 24, 94, 72, 18, 8, 46, 29, 32, 40, 62, 76, 36],
                 [20, 69, 36, 41, 72, 30, 23, 88, 34, 62, 99, 69, 82, 67, 59, 85, 74, 4, 36, 16],
                 [20, 73, 35, 29, 78, 31, 90, 1, 74, 31, 49, 71, 48, 86, 81, 16, 23, 57, 5, 54],
                 [1, 70, 54, 71, 83, 51, 54, 69, 16, 92, 33, 48, 61, 43, 52, 1, 89, 19, 67, 48]]

    global temp
    temp = 0
    product = 0
    numbers = []
    location = []

    #横向对比
    for line in range (20):
        for horitem in range(17):
            product = numsquare[line][horitem]*\
                      numsquare[line][horitem+1]*\
                      numsquare[line][horitem+2]*\
                      numsquare[line][horitem+3]
            if product > temp:
                temp = product
                numbers = [numsquare[line][horitem],
                           numsquare[line][horitem+1],
                           numsquare[line][horitem+2],
                           numsquare[line][horitem+3]]
                location = [[line,horitem+1],
                            [line,horitem+2],
                            [line,horitem+3],
                            [line,horitem+4]]

    #纵向对比
    for line in range (20):
        for vertitem in range(17):
            product = numsquare[vertitem][line]*\
                      numsquare[vertitem+1][line]*\
                      numsquare[vertitem+2][line]*\
                      numsquare[vertitem+3][line]
            if product > temp:
                temp = product
                numbers = [numsquare[vertitem][line],
                           numsquare[vertitem+1][line],
                           numsquare[vertitem+2][line],
                           numsquare[vertitem+3][line]]
                location = [[vertitem+1,line+1],
                            [vertitem+2,line+1],
                            [vertitem+3,line+1],
                            [vertitem+4,line+1]]

    #右斜对比
    for horiline in range (17):
        for vertiline in range(17):
            product = numsquare[horiline][vertiline]*\
                      numsquare[horiline+1][vertiline+1]*\
                      numsquare[horiline+2][vertiline+2]*\
                      numsquare[horiline+3][vertiline+3]
            if product > temp:
                temp = product
                number = [numsquare[horiline][vertiline],
                          numsquare[horiline+1][vertiline+1],
                          numsquare[horiline+2][vertiline+2],
                          numsquare[horiline+3][vertiline+3]]
                location = [[horiline+1,vertiline+1],
                            [horiline+2,vertiline+2],
                            [horiline+3,vertiline+3],
                            [horiline+4,vertiline+4]]

    #左斜对比
    for rehoriline in range(17):
        for revertiline in range(19,2,-1):
            product = numsquare[rehoriline][revertiline]*\
                      numsquare[rehoriline+1][revertiline-1]*\
                      numsquare[rehoriline+2][revertiline-2]*\
                      numsquare[rehoriline+3][revertiline-3]
            if product > temp:
                temp = product
                numbers = [numsquare[rehoriline][revertiline],
                           numsquare[rehoriline+1][revertiline-1],
                           numsquare[rehoriline+2][revertiline-2],
                           numsquare[rehoriline+3][revertiline-3]]
                location = [[rehoriline+1,revertiline+1],
                            [rehoriline,revertiline],
                            [rehoriline-1,revertiline-1],
                            [rehoriline-2,revertiline-2]]

    print("在该矩阵中连续四个数字的乘积最大为:%d" %temp)
    print("这四个数字是:%d,%d,%d,%d" %(numbers[0],numbers[1],numbers[2],numbers[3]))
    print("这四个数字的位置在:" + str(location))


start_findmax = time.time()
findmax()
time_findmax = time.time() - start_findmax
print("%f秒" %time_findmax)


在该矩阵中连续四个数字的乘积最大为:70600674
这四个数字是:89,94,97,87
这四个数字的位置在:[[13, 7], [12, 6], [11, 5], [10, 4]]
0.000473秒
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-5 17:08:02 | 显示全部楼层
n = '08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08 49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00 81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65 52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91 22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80 24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50 32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70 67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21 24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72 21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95 78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92 16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57 86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58 19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40 04 52 08 83 97 35 99 16 07 97 57 32 16 26 26 79 33 27 98 66 88 36 68 87 57 62 20 72 03 46 33 67 46 55 12 32 63 93 53 69 04 42 16 73 38 25 39 11 24 94 72 18 08 46 29 32 40 62 76 36 20 69 36 41 72 30 23 88 34 62 99 69 82 67 59 85 74 04 36 16 20 73 35 29 78 31 90 01 74 31 49 71 48 86 81 16 23 57 05 54 01 70 54 71 83 51 54 69 16 92 33 48 61 43 52 01 89 19 67 48'
number = []
n1 = list(n.split())
for each in n1:
    number.append(int(each))

num = []
for i in range(20):
    num.append(number[i * 20: (i + 1) * 20])

temp = 0
for x in range(17):
    for y in range(17):
        a = num[x][y] * num[x + 1][y + 1] * num[x + 2][y + 2] * num[x + 3][y + 3]
        b = num[x][y + 3] * num[x + 1][y + 2] * num[x + 2][y + 1] * num[x + 3][y]
        if a > temp:
            temp = a
        if b > temp:
            temp = b
    c = num[x][x] * num[x][x + 1] * num[x][x + 2] * num[x][x + 3]
    d = num[x][x] * num[x + 1][x] * num[x + 2][x] * num[x + 3][x]
    if c > temp:
        temp = c
    if d > temp:
        temp = d
print (temp)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-3-6 20:13:56 | 显示全部楼层
#include <stdio.h>

main()
{
        int a[20][20] = {                { 8, 2,22,97,38,15, 0,40, 0,75, 4, 5, 7,78,52,12,50,77,91, 8},
                                                {49,49,99,40,17,81,18,57,60,87,17,40,98,43,69,48, 4,56,62, 0},
                                                {81,49,31,73,55,79,14,29,93,71,40,67,53,88,30, 3,49,13,36,65},
                                                {52,70,95,23, 4,60,11,42,69,24,68,56, 1,32,56,71,37, 2,36,91},
                                                {22,31,16,71,51,67,63,89,41,92,36,54,22,40,40,28,66,33,13,80},
                                                {24,47,32,60,99, 3,45, 2,44,75,33,53,78,36,84,20,35,17,12,50},
                                                {32,98,81,28,64,23,67,10,26,38,40,67,59,54,70,66,18,38,64,70},
                                                {67,26,20,68, 2,62,12,20,95,63,94,39,63, 8,40,91,66,49,94,21},
                                                {24,55,58, 5,66,73,99,26,97,17,78,78,96,83,14,88,34,89,63,72},
                                                {21,36,23, 9,75, 0,76,44,20,45,35,14, 0,61,33,97,34,31,33,95},
                                                {78,17,53,28,22,75,31,67,15,94, 3,80, 4,62,16,14, 9,53,56,92},
                                                {16,39, 5,42,96,35,31,47,55,58,88,24, 0,17,54,24,36,29,85,57},
                                                {86,56, 0,48,35,71,89, 7, 5,44,44,37,44,60,21,58,51,54,17,58},
                                                {19,80,81,68, 5,94,47,69,28,73,92,13,86,52,17,77, 4,89,55,40},
                                                { 4,52, 8,83,97,35,99,16, 7,97,57,32,16,26,26,79,33,27,98,66},
                                                {88,36,68,87,57,62,20,72, 3,46,33,67,46,55,12,32,63,93,53,69},
                                                { 4,42,16,73,38,25,39,11,24,94,72,18, 8,46,29,32,40,62,76,36},
                                                {20,69,36,41,72,30,23,88,34,62,99,69,82,67,59,85,74, 4,36,16},
                                                {20,73,35,29,78,31,90, 1,74,31,49,71,48,86,81,16,23,57, 5,54},
                                                { 1,70,54,71,83,51,54,69,16,92,33,48,61,43,52, 1,89,19,67,48} };

        
        int i, j; 
        int max = 0, h, v, left, right;

        for (i = 0; i < 20; i++)
        {
                for (j = 0; j < 20; j++)
                {
                        if (a[i][j] == 0)
                        {
                                goto Label;
                        }
                        if (i <= 16 && (j >= 3 && j <= 16))
                        {
                                //横
                                h = a[i][j] * a[i][j + 1] * a[i][j + 2] * a[i][j + 3];
                                //竖
                                v = a[i][j] * a[i + 1][j] * a[i + 2][j] * a[i + 3][j];
                                //左倾斜对角线
                                left = a[i][j] * a[i + 1][j - 1] * a[i + 2][j - 2] * a[i + 3][j - 3];
                                //右倾斜对角线
                                right = a[i][j] * a[i + 1][j + 1] * a[i + 2][j + 2] * a[i + 3][j + 3];        

                                max = max > h ? max : h;
                                max = max > v ? max : v;
                                max = max > left ? max : left;
                                max = max > right ? max : right;
                        }
                        if (i <= 16 && j < 3 ) //此时左倾斜数据不够
                        {
                                //水平
                                h = a[i][j] * a[i][j + 1] * a[i][j + 2] * a[i][j + 3];
                                //垂直
                                v = a[i][j] * a[i + 1][j] * a[i + 2][j] * a[i + 3][j];
                                //右倾斜对角线
                                right = a[i][j] * a[i + 1][j + 1] * a[i + 2][j + 2] * a[i + 3][j + 3];

                                max = max > h ? max : h;
                                max = max > v ? max : v;
                                max = max > right ? max : right;
                        }
                        if (i <= 16 && j > 16) //此时右倾斜数据不够
                        {
                                //水平
                                h = a[i][j] * a[i][j + 1] * a[i][j + 2] * a[i][j + 3];
                                //垂直
                                v = a[i][j] * a[i + 1][j] * a[i + 2][j] * a[i + 3][j];
                                //左倾斜对角线
                                left = a[i][j] * a[i + 1][j - 1] * a[i + 2][j - 2] * a[i + 3][j - 3];

                                max = max > h ? max : h;
                                max = max > v ? max : v;
                                max = max > left ? max : left;                                
                        }
                        if (i > 16 && j <= 16) //此时只需计算水平方向的数据
                        {
                                h = a[i][j] * a[i][j + 1] * a[i][j + 2] * a[i][j + 3];
                                
                                max = max > h ? max : h;

                        }
                        else if (i > 16 && j > 16) //此时所有方向数据都不够
                        {
                                continue;
                        }
                Label:continue;
                }

        }
        printf("连续四个数乘积最大值为:%d\n", max);
}
若有错误,希望大佬帮忙纠正!!!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-8-10 23:02:44 | 显示全部楼层
#include <stdio.h>

int count = 0;

int matrix[20][20] = {
        { 8, 2,22,97,38,15, 0,40, 0,75, 4, 5, 7,78,52,12,50,77,91, 8},
        {49,49,99,40,17,81,18,57,60,87,17,40,98,43,69,48, 4,56,62, 0},
        {81,49,31,73,55,79,14,29,93,71,40,67,53,88,30, 3,49,13,36,65},
        {52,70,95,23, 4,60,11,42,69,24,68,56, 1,32,56,71,37, 2,36,91},
        {22,31,16,71,51,67,63,89,41,92,36,54,22,40,40,28,66,33,13,80},
        {24,47,32,60,99, 3,45, 2,44,75,33,53,78,36,84,20,35,17,12,50},
        {32,98,81,28,64,23,67,10,26,38,40,67,59,54,70,66,18,38,64,70},
        {67,26,20,68, 2,62,12,20,95,63,94,39,63, 8,40,91,66,49,94,21},
        {24,55,58, 5,66,73,99,26,97,17,78,78,96,83,14,88,34,89,63,72},
        {21,36,23, 9,75, 0,76,44,20,45,35,14, 0,61,33,97,34,31,33,95},
        {78,17,53,28,22,75,31,67,15,94, 3,80, 4,62,16,14, 9,53,56,92},
        {16,39, 5,42,96,35,31,47,55,58,88,24, 0,17,54,24,36,29,85,57},
        {86,56, 0,48,35,71,89, 7, 5,44,44,37,44,60,21,58,51,54,17,58},
        {19,80,81,68, 5,94,47,69,28,73,92,13,86,52,17,77, 4,89,55,40},
        { 4,52, 8,83,97,35,99,16, 7,97,57,32,16,26,26,79,33,27,98,66},
        {88,36,68,87,57,62,20,72, 3,46,33,67,46,55,12,32,63,93,53,69},
        { 4,42,16,73,38,25,39,11,24,94,72,18, 8,46,29,32,40,62,76,36},
        {20,69,36,41,72,30,23,88,34,62,99,69,82,67,59,85,74, 4,36,16},
        {20,73,35,29,78,31,90, 1,74,31,49,71,48,86,81,16,23,57, 5,54},
        { 1,70,54,71,83,51,54,69,16,92,33,48,61,43,52, 1,89,19,67,48}
};
int main(void)
{
        int x,y;
        int max, max_x = 0, max_y = 0;
        int result = 0;
        
        for(y = 0;y<=16;y++)
        {
                for(x=0;x<=16;x++)
                {
                        count += 1;
                        result = (matrix[y][x] * matrix[y+1][x+1] * matrix[y+2][x+2] * matrix[y+3][x+3]);
                        if (result > max){
                                max = result;
                                max_x = x;
                                max_y = y; 
                        }
                }
        }
        
        printf("%d * %d * %d * %d = %d\n", matrix[max_y][max_x], matrix[max_y+1][max_x+1], matrix[max_y+2][max_x+2], matrix[max_y+3][max_x+3], max);
        printf("count = %d\n", count);
        return 0;
}
//94 * 99 * 71 * 61 = 40304286
//count = 289
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-10-12 12:41:54 | 显示全部楼层
s ='''08 02 22 97 38 15 00 40 00 75 04 05 07 78 52 12 50 77 91 08
49 49 99 40 17 81 18 57 60 87 17 40 98 43 69 48 04 56 62 00
81 49 31 73 55 79 14 29 93 71 40 67 53 88 30 03 49 13 36 65
52 70 95 23 04 60 11 42 69 24 68 56 01 32 56 71 37 02 36 91
22 31 16 71 51 67 63 89 41 92 36 54 22 40 40 28 66 33 13 80
24 47 32 60 99 03 45 02 44 75 33 53 78 36 84 20 35 17 12 50
32 98 81 28 64 23 67 10 26 38 40 67 59 54 70 66 18 38 64 70
67 26 20 68 02 62 12 20 95 63 94 39 63 08 40 91 66 49 94 21
24 55 58 05 66 73 99 26 97 17 78 78 96 83 14 88 34 89 63 72
21 36 23 09 75 00 76 44 20 45 35 14 00 61 33 97 34 31 33 95
78 17 53 28 22 75 31 67 15 94 03 80 04 62 16 14 09 53 56 92
16 39 05 42 96 35 31 47 55 58 88 24 00 17 54 24 36 29 85 57
86 56 00 48 35 71 89 07 05 44 44 37 44 60 21 58 51 54 17 58
19 80 81 68 05 94 47 69 28 73 92 13 86 52 17 77 04 89 55 40
04 52 08 83 97 35 99 16 07 97 57 32 16 26 26 79 33 27 98 66
88 36 68 87 57 62 20 72 03 46 33 67 46 55 12 32 63 93 53 69
04 42 16 73 38 25 39 11 24 94 72 18 08 46 29 32 40 62 76 36
20 69 36 41 72 30 23 88 34 62 99 69 82 67 59 85 74 04 36 16
20 73 35 29 78 31 90 01 74 31 49 71 48 86 81 16 23 57 05 54
01 70 54 71 83 51 54 69 16 92 33 48 61 43 52 01 89 19 67 48
'''
#转换为二维列表
#'''
index = 0
list1 = []
s_list = []
while True:
    list1.append(s[index:index+2])
    index += 3
    if index in [i for i in range(60, 1200, 60)]:
        s_list.append(list1)
        list1 = []
        continue
        
    if index == 1200:
        s_list.append(list1)
        list1 = []
        break
#print(s_list)
#'''
a,b,c,d = 0,0,0,0
row = 0
result = []
res = 1
position = []     
while (row + 1):
    for column in range(20):
        #向右
        if column <= 16:
            res = int(s_list[row][column]) * int(s_list[row][column+1]) *\
                  int(s_list[row][column+2]) * int(s_list[row][column+3])
            result.append(res)
            result = [max(result)]
            if res == max(result):
                position = []
                position.append(s_list[row][column])
                position.append(s_list[row][column+1])
                position.append(s_list[row][column+2])
                position.append(s_list[row][column+3])

            #向下
            res = int(s_list[row][column]) * int(s_list[row+1][column]) *\
                  int(s_list[row+2][column]) * int(s_list[row+3][column])
            result.append(res)
            result = [max(result)]
            if res == max(result):
                position = []
                position.append(s_list[row][column])
                position.append(s_list[row+1][column])
                position.append(s_list[row+2][column])
                position.append(s_list[row+3][column])
                result = [max(result)]

            #向右下
            res = int(s_list[row][column]) * int(s_list[row+1][column+1]) *\
                  int(s_list[row+2][column+2]) * int(s_list[row+3][column+3])
            result.append(res)
            result = [max(result)]
            if res == max(result):
                position = []
                position.append(s_list[row][column])
                position.append(s_list[row+1][column+1])
                position.append(s_list[row+2][column+2])
                position.append(s_list[row+3][column+3])

    row += 1
    if row == 17:
        break
a = position[0]
b = position[1]
c = position[2]
d = position[3]
e = result[0]
print("乘积最大的四个数字是:%s * %s * %s * %s = %s" % (a,b,c,d,e))
     

            
   
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-22 19:05

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表