我正在尝试编写代码来测试是否n^2 + (n+1)^2完美。由于我在编程方面没有太多经验,所以我只能使用 Matlab。到目前为止,这是我尝试过的
function [ Liste ] = testSquare(N)
        if exist('NumberTheory')
           load NumberTheory.mat
        else
            MaxT = 0;
        end
        if MaxT > N 
            return
        elseif MaxT > 0 
            L = 1 + MaxT;
        else
            L = 1;
        end
    n = (L:N)';            % Makes a list of numbers from L to N
    m = n.^2 + (n+1).^2;   % Makes a list of numbers on the form A^2+(A+1)^2
    P = dec2hex(m);        % Converts this list to hexadecimal 
    Length = length(dec2hex(P(N,:))); %F inds the maximum number of digits in the hexidecimal number
    Modulo = ['0','1','4','9']';      % Only numbers ending on 0,1,4 or 9 can be perfect squares in hex
    [d1,~] = ismember(P(:,Length),Modulo); % Finds all numbers that end on 0,1,4 or 9
    m = m(d1);                             % Removes all numbers not ending on 0,1,4 or 9
    n = n(d1);                             % -------------------||-----------------------
   mm = sqrt(m);                           % Takes the square root of all the possible squares
    A = (floor(mm + 0.5).^2 == m);         % Tests wheter these are actually squares
   lA = length(A(A>0));                    % Finds the number of such numbers
   MaxT = N;
   save NumberTheory.mat MaxT;
if lA>0
    m = m(A);                              % makes a list of all the square numbers
    n = n(A);                              % finds the corresponding n values
   mm = mm(A);                             % Finds the squareroot values of m 
    fid = fopen('Tallteori.txt','wt');     % Writes everything to a simple text.file
        for ii = 1:lA
            fprintf(fid,'%20d %20d %20d\t',n(ii),m(ii),mm(ii));
            fprintf(fid,'\n');
        end
    fclose(fid);
end
end
这会将具有相应 n 值的正方形写入文件。现在我看到使用十六进制是在 C+ 中找到完美正方形的一种快速方法,并尝试在 matlab 中使用它。但是我有点不确定这是否是最好的方法。
m > 2^52由于十六进制转换,上面的代码会崩溃。
是否有另一种方法/更快地将表单上的所有完美正方形写入n^2 + (n+1)^2从 1 到 N 的文本文件?