2016-08-02 12 views
5

Là một cái gì đó mới, tôi đang cố gắng hoàn thành Bài toán số 5 của dự án Euler, với tập lệnh theo lô (https://projecteuler.net/problem=5). Tuy nhiên; Tôi đã gặp một vài vấn đề. Nếu bất cứ ai có thể đi qua mã của tôi, đó sẽ là tuyệt vời.Thực hiện số học mô-đun trong một tập lệnh hàng loạt

@ECHO off 

SET init=1 
SET iter=1 
SET /a func=%init% %% %iter% 
cls 

:Num 
IF func==0 (
    IF iter==20 (
     ECHO Val = %init% 
     pause 
     exit 
    ) ELSE (
     SET /a iter+=1 
     GOTO Num 
    ) 
) ELSE (
    SET iter=1 
    SET /a init+=1 
    GOTO Num 
) 

gì nó có nghĩa là phải làm là kiểm tra xem init mod iter trả về 0, và nếu có, thêm 1 với giá trị iter, cho đến khi nó đạt đến 21. Tuy nhiên; nếu nó không bằng 0, số lần lặp lại sẽ được đặt về 0 và sẽ bắt đầu tính lại.


Một ví dụ về những gì đang có nghĩa là để xảy ra:

1 mod 1 = 0, Therefor add 1 to iter 
1 mod 2 != 0, Therefor init is set to 0 and 1 is added to init 
2 mod 1 = 0, Therefor add 1 to iter 
2 mod 2 = 0, Therefor add 1 to iter 
2 mod 3 != 0, Therefor init is set to 0 and 1 is added to init 

Và vân vân và vân vân.


Một ví dụ về những gì KHÔNG xảy ra:

1 mod 1 != 0, Therefor add 1 to init 
2 mod 1 != 0, Therefor add 1 to init 
3 mod 1 != 0, Therefor add 1 to init 

Và vân vân và vân vân.



Bất kỳ trợ giúp nào được đánh giá cao, cảm ơn.

+0

Tôi đã thực hiện một vài thay đổi đối với mã, tuy nhiên; bây giờ nó bỏ qua số học modulus hoàn toàn và nói rằng 1 mod 1-20 = 0. Suy nghĩ về lý do tại sao nó làm điều này? '@ECHO tắt SET init = 1 SET iter = 1 SET/A func = "% init% %%% iter%" cls : Num NẾU "% func%" == "0 "( \t NẾU "% iter%" == "21"( \t \t tiếng vang. \t \t ECHO Val =% init% \t \t tiếng vang. \t \t vang Nhấn phím bất kỳ để thoát... \t \t p ause> nul \t \t thoát \t) ELSE ( \t \t echo% init% mod% iter% = 0; CONT \t \t SET/A ITER + = 1 \t \t GOTO Num \t) ) ELSE ( echo% init% mod% iter%!= 0; BREAK \t SET iter = 1 \t SET/A init + = 1 \t GOTO Num ) ' Xin lỗi cho các định dạng xấu xí. – Sennsei

+3

Bạn không bao giờ tính toán lại '% func%'. – SomethingDark

+0

Tôi sẽ kết hợp điều này như thế nào? – Sennsei

Trả lời

0

Làm thế nào về điều này: (!?)

@Echo off 
setlocal enabledelayedexpansion 
SET init=1 
SET iter=1 
cls 
set loopCounter=1 
set loopBatch=1 

:numLoop 
SET /a func="!init! %% !iter!" 
IF !iter! == 21 (goto :done) 
IF !func! == 0 (call :incIter) ELSE (call :incInit) 
SET /a loopCounter+=1 
SET /a loopBatch="%loopCounter% %% 1000" 
if !loopBatch! == 0 (echo %loopCounter% iterations done) 
goto :numLoop 

:incInit 
    rem echo %init% mod %iter% == %func%; Increasing init 
    SET iter=1 
    SET /a init+=1 
    goto :eof 

:incIter 
    rem echo %init% mod %iter% == %func%; Increasing iter 
    SET /a iter+=1 
    goto :eof 

:done 
    echo. 
    ECHO Val = %init% 
0

Chỉ cần gửi một "thực tế" Giải pháp chỉ trong trường hợp ai đó có thể tìm thấy nó "hữu ích"

@echo off 
    setlocal enableextensions enabledelayedexpansion 

    rem Our search limit 
    set "limit=20" 
    rem Note: batch arithmetic is limited to 2^31 values, so 26 is the highest 
    rem  value that we can directly use 

    rem Initialize searched number 
    set "euler5=1" 

    rem Initialize list of numbers for a Erastotenes cribe 
    for /l %%a in (2 1 %limit%) do set "f.%%a=%%a" 

    rem Search for prime numbers and simplify (divide) greater multiples 
    rem Keep multiplying as we iterate over the list 
    for /l %%a in (2 1 %limit%) do (
     if !f.%%a! gtr 1 (
      set /a "euler5*=!f.%%a!" 
      for %%c in (!f.%%a!) do for /l %%b in (%%a %%a %limit%) do (
       set /a "f.%%b/=%%c" 
      ) 
     ) 
    ) 

    rem Echo solution 
    echo %euler5% 
0

theo (!!?) liên kết này: link có một toán tử mô-đun.

Vì vậy, bạn có thể thử này để thay thế

@echo off 

::we should start with 21 because we know that all numbers from 1-20 
::cannot be divided by 20 all 20 times. 
::This will also fix the problem of an unwanted a zero remainder at the 
::early numbers 

set count=21 
set divide=1 
::We need to set enabledelayedexpansion so we can use ! as a varible 
::expander. 
setlocal enabledelayedexpansion 

:loop 
:: begin the modulus operator. 
set /a remainder=!count!%%!divide! 
if %remainder%==0 (
if %divide%==20 
::Yea! 
echo number found:%count% 
::Don't forget to pause 
::or else you cant see the number. 
pause 
) else (
set /a divide=%divide%+1 
::equivelent to set /a divide+=1 
goto :loop 
) 
) else (
set /a count=%count%+1 
goto :loop 
) 

Mặc dù điều này không sửa chữa kịch bản của bạn, nó chắc chắn là một cách nhanh hơn.

Các vấn đề liên quan