用线程 计算 水仙花数

本文介绍了一种使用Delphi实现的水仙花数查找算法,通过创建线程并利用循环和数学运算,从指定范围中找出所有水仙花数,并记录运行时间,展示算法效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

unit NarcissisticnumberU;

interface
   uses Classes,  System.SysUtils, math  ;
   type
     TNarcissisticnumbeThread=class;//定义一个水仙花数类
     TOnRuned =procedure(sender:TNarcissisticnumbeThread ) of object;//方法过程
     TNarcissisticnumbeThread=class(TThread)
   protected
            procedure Execute; override;
   public
            BeginNum:integer;//初始值
            EndNum:integer;//终止值
            NarcissisticNum:STRING ;//  水仙花数
           onRuned: TOnRuned
   end  ;

implementation
    procedure TNarcissisticnumbeThread.Execute;
 var
    x,s,e:LongInt;
    i,j,m,L,d :integer;
    st:string;
 

 begin
     NarcissisticNum:='';
         for x:=BeginNum  to EndNum do
         begin
             str(x,st)  ;     L:=length(st) ;   S:=0;
              for i :=1 to L do
                   begin
                        e:=1;
                        val(st[i],m,d);
                         for   j :=  1 to L do
                              e:=e*m;
                       s:=s+e;
                 end;//   for i :=1 to L do

             if x=s  then  NarcissisticNum:=NarcissisticNum +X.ToString  +#13+#10;


         end; // for x:=BeginNum  to EndNum do

         if assigned(onRuned) then
             onRuned(self)

    end;

end.

/

 

 

unit UNarcissisticnumbe;

interface

uses
  Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
  Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, NarcissisticnumberU  ;


type
  TTFrmMain = class(TForm)
    Button1: TButton;
    Memo1: TMemo;
    procedure Button1Click(Sender: TObject);
  private
    { Private declarations }
   lStart, lEnd : Longint;
   procedure ShowRunTime(const lTime : Longint);
   procedure    onRuned(Sender:TNarcissisticnumbeThread )  ;

  public
    { Public declarations }
  end;

var
  TFrmMain: TTFrmMain;

implementation

{$R *.dfm}


procedure TTFrmMain.Button1Click(Sender: TObject);
var
        MYThread: TNarcissisticnumbeThread;
begin
        MYThread := TNarcissisticnumbeThread.Create(true);
        MYThread.onRuned:= self.onRuned; //指定事件。
        MYThread.FreeOnTerminate := true; // 线程结束后自动释放
        MYThread.BeginNum := 100;
       MYThread.EndNum:=9999999;
       MYThread.Start;
      lStart := GetTickCount;
end;
procedure TTFrmMain.onRuned(Sender: TNarcissisticnumbeThread);
begin
    TThread.Synchronize(nil,
    procedure
     begin
         memo1.Lines.Text:=(sender.NarcissisticNum) ;
          lEnd := GetTickCount;
          ShowRunTime(lEnd - lStart);
     end);
end;
procedure TTFrmMain.ShowRunTime(const lTime: Integer);
begin
  memo1.Lines.Add(FloatToStr(lTime / 1000.0) + '秒');
end;
end.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值