全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:2612
推到 Plurk!
推到 Facebook!

電話號碼上的英文字母排列組合

尚未結案
tabo
一般會員


發表:1
回覆:0
積分:0
註冊:2004-05-12

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-05-13 11:32:39 IP:24.226.xxx.xxx 未訂閱
電話機上不是有英文字母嗎 例如: 按鍵'2' 上有 ABC, 按鍵'3' 上有 DEF 請問 如果輸入一組數字, 如'637' 有沒有辦法用recursion 的方法排列出所有組合呢? 輸出結果如下: MDP MEP MFP NDP NEP NFP ODP OEP OFP MDR MER MFR NDR NER NFR ODR OER OFR MDS MES MFS NDS NES NFS ODS OES OFS
timhuang
尊榮會員


發表:78
回覆:1815
積分:1608
註冊:2002-07-15

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-05-26 00:01:14 IP:61.62.xxx.xxx 未訂閱
Hi, 使用了 delphi 寫個 sample 給你參考, 這是非 recursive 的作法, 若要 recursive 的作法, 我再寫一個給你參考:    
procedure TForm1.Button1Click(Sender: TObject);
var
  aChar: Array[2..9] of string;
  sInput: string;
  slresult, sltemp: TStringList;
  i, j, k: integer;
begin
  aChar[2] := 'ABC';
  aChar[3] := 'DEF';
  aChar[4] := 'GHI';
  aChar[5] := 'JKL';
  aChar[6] := 'MNO';
  aChar[7] := 'PQRS';
  aChar[8] := 'TUV';
  aChar[9] := 'WXYZ';
  sInput   := Edit1.Text;  // ex: '637'      slresult:= TStringList.Create;
  sltemp  := TStringList.Create;      for i := 1 to Length(sInput) do
  begin
    sltemp.Clear;
    for j := 1 to Length(aChar[StrToInt(sInput[i])]) do
    begin
      if slresult.Count = 0 then
        sltemp.Add(aChar[StrToInt(sInput[i])][j])
      else
      begin
        for k := 0 to slresult.Count -1 do
        begin
          sltemp.Add(slresult[k] aChar[StrToInt(sInput[i])][j]);
        end;
      end;
    end;
    slresult.Text := sltemp.Text;
  end;      Memo1.Lines.Text := slresult.Text;  // display the result!      sltemp.Free;
  slresult.Free;
end;
ps. 637 的結果應該是 3 * 3 * 4 = 36 組, 你的 7 按鍵有少個 q 所以列出 27 組而已 !!
系統時間:2024-11-21 19:30:45
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!