
素因数分解のプログラムを作成しました。
なぜか11桁を超えた場合、正しく表示されません!!
アドバイス等お願いします。
あと、処理時間も組んでみましたがこちらもうまくいきません。
改善をお願いしますm(_ _)m
#include<stdio.h>
#include<time.h>
void fanction(int);
void main(void)
{
int n;
clock_t start_time, end_time;
printf("整数を入力してください。\n");
scanf("%d",&n);
start_time = clock();
fanction(n);
end_time = clock();
printf("\n\n処理時間:%.3f秒\n",(double)(end_time - start_time) / CLOCKS_PER_SEC);
return 0;
}
void fanction(int n)
{
int m;
char c='=';
for(m=2;n != 1;m++)
{
while(n%m == 0)
{
n = n/m;
printf("%c%d",c,m);
c='*';
}
}
}
A 回答 (5件)
- 最新から表示
- 回答順に表示
No.5
- 回答日時:
回答の訂正です。
(int型を32bit符号付きと仮定しています)for (m=2; n!=1; m++) を
誤>for (m=2; n>m*m; m++) に変えて、このループを終了した後でnの値を出力する
正>for(m=2;(m<46340)&&(n>=m*m);m++) に変えて、このループを終了した後に
正>if (n>1) printf("%c%d",c,n); を入れる
ここに出てくる46340は最大数2147483647の平方根を切り捨てた値です。mがこれより大きいと、m*mで桁あふれが起きてループが終わらなくなることがあります。
No.4
- 回答日時:
処理時間をミリ秒単位まで正確に計時できているかどうかは別として、大きな素数を入力すればゼロでない所要時間が表示されます。
たとえば、入力値として、32ビット符号付き整数の最大値2147483647(メルセンヌ素数といわれる素数です)を入れて処理が終わるまで待ってみたらどうでしょうか。
時間を短縮したいなら、
for (m=2; n!=1; m++) を
for (m=2; n>m*m; m++) に変えて、このループを終了した後でnの値を出力するようにすると効果があります。
No.3
- 回答日時:
>処理時間も組んでみましたがこちらもうまくいきません。
どんな風にうまくいかないのか、症状を具体的に書きましょう。
# start_time と end_time とが同じで、どんな数値を素因数分解しても
実行時間がゼロ秒になるってこと?
No.2
- 回答日時:
Cの整数型(char,short,int,long等)は、高々、数~数十bitの精度しかありません。
例えば、WindowsのVisual C++なら、int型は32bitであり、(- 2の31乗)から(2の31乗 -1)までの数しか表わせません。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
#if 1 #elseの意味について
-
構文エラー";"が型の前にあり...
-
getcの改行判定
-
配列を関数に渡す方法
-
初心者です。for文、if文を使っ...
-
最早開始時間と最遅完了時刻を...
-
【C++】関数ポインタの使い方
-
既定のコンストラクタがありま...
-
Aの値からBの値を除するとは??
-
「Aに対するBの割合」と「Aに対...
-
信頼区間の1.96や1.65ってどこ...
-
a^2の√=a が成り立たない場合
-
VB6.0での小数点の扱いについて
-
配列をnビットシフトする
-
数学 一次関数 関数 y=-3/4x+k(...
-
c languageで 簡単な質問があ...
-
C言語 エラーの原因がわからな...
-
#define _CRT_SECURE_NO_WARNIN...
-
プログラムでの数字につく”f”の...
-
C言語で複数列のデータを1列の...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
#if 1 #elseの意味について
-
構文エラー";"が型の前にあり...
-
for文の中にswitch文はいれられ...
-
配列を使って魔方陣
-
C言語 数字以外を入力させない...
-
10進数からN進数に変換するプロ...
-
配列を関数に渡す方法
-
scanfが実行されません
-
C言語で電卓を作成する。
-
C言語・最大値を算出するプロ...
-
C言語階乗の総和を求める
-
実行すると if文 に矛盾
-
計算結果がlong型以上になる場...
-
C言語プログラム
-
C言語。どうしてコンパイルでき...
-
c言語for文
-
getcの改行判定
-
C言語で勉強中(max,min)の出し方
-
C言語 プログラム
-
SIGALRMでプロセス終了
おすすめ情報