
2以上の整数が与えられたとき、それを素数の積に分解するプログラムを作成したいのです。
例えば、TextBox1に24と打ち込んで、Button1をクリックすると、TextBox2に2×2×2×3が表示されるといった具合です。
↓ここからどうすれば良いか、ご教授お願い致します。
Private Sub IntegerButton1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
Dim n, a As Integer
n = TextBox1.Text
Do
back:
If n Mod 2 = 0 Then
n = n Mod 2 = 0
Else
n = n Mod 3 = 0
End If
GoTo back
Loop Until n = n + 1
TextBox2.Text = n & "×"
End Sub
End Class
No.1ベストアンサー
- 回答日時:
じぶんだったら、
pl: 素因数のリスト
N: 対象
m: 現在の素因数候補
として、
if N mod m = 0 then
plにmを追加。
N = N / m
else
m = m + 1
end
をループさせて、plを完成させる――というプログラムにしますね。
多少効率を考えると、m=2を特別扱いし、m=3,5,7,...[√N]の範囲でループさせるとか。
No.2
- 回答日時:
作ってみました
Dim n As Long = TextBox1.Text
Dim m As Long = 2
Dim pl As ArrayList = New ArrayList
If (n <= 1) Then
Label1.Text = "NG"
Exit Sub
End If
While n >= m * m
While n Mod m = 0
pl.Add(m.ToString())
n /= m
End While
If (m = 2) Then
m = 3
Else
m += 2
End If
End While
If (n > 1) Then
pl.Add(n.ToString())
End If
Label1.Text = String.Join("×", CType(pl.ToArray(GetType(String)), String()))
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「偶数・奇数の和」のフローチ...
-
Escキーを押すと、中断する時と...
-
範囲指定したセルを1つずつ飛...
-
乱数の桁数指定、または範囲指定。
-
画面を強制的に再描画させる方法
-
Pro Tools の 波形を伸ばす方...
-
エクセル2010のコマンドボタン...
-
流れ図(フローチャート)が分か...
-
VBA Boxが空白の場合のメッセー...
-
3を2001乗したときの一の位 の...
-
DoEventsが必要な理由について
-
メッセージループを調べすぎてC...
-
イベントの発生を待つ
-
VBA Dir関数でファイルをループ...
-
ListBox 複数選択 で オートフ...
-
多重ループの抜けだし方
-
VBAで3秒だけ時間を止めたい
-
ループフリー
-
再帰関数のインライン展開
-
VBA エクセル2010 横長データ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
画面を強制的に再描画させる方法
-
UWSCの終了の仕方
-
CSVファイルの特定の行だけを読...
-
範囲指定したセルを1つずつ飛...
-
UWSCに制限時間を付けたいです
-
Escキーを押すと、中断する時と...
-
乱数の桁数指定、または範囲指定。
-
VBA for i=1 to lastrow
-
流れ図(フローチャート)が分か...
-
DOSコマンドのループ内のTIMEコ...
-
pythonでファイルのコメント行...
-
素数表について。
-
「偶数・奇数の和」のフローチ...
-
VBAでの一時停止と再開の方法
-
DoEventsが必要な理由について
-
vb.netです。2次元配列の要素を...
-
ループフリー
-
Do whileでExitせず、ループの...
-
エクセルの当番表を作っていま...
-
VBAで3秒だけ時間を止めたい
おすすめ情報