プログラムが…
以下のプログラムを作っているのですが、よく分かりません・・・
A監督が 77,B走塁コーチは 78 です.さて,77 と 78の素因数の和は等しくなっています.
つまり,77=7×11,78=2×3×13,7+11=18,2+3+13=18 となっています.
このように,素因数の和が互いに等しいという条件を満たすような,
差が 1 の自然数の組を 20000 以下でできるだけ多く探索しましょう.
ここで,20000 以下には 26 組しかないことがわかっています.
#include<stdio.h>
#difine MAX 20000
int main(){
int sum[MAX+1];
int i,j,n;
for(i = 2;i <= MAX;i++){
j = 2;
while(j*j <= i){
if(i % j == 0){
_________________;
break;
}
else
j++;
}
if(j*j > i)
___________________;
}
n = 0;
for(i = 2;i < MAX;i++)
if(sum[i] == sum[i+1]){
n++;
printf("%3d (%d,%d)\n",n,i,i+1);
}
return 0;
}
補足
分からないのはプログラムの書き方で
_________________;の部分だけでも答えていただけるとありがたいです。
A 回答 (5件)
- 最新から表示
- 回答順に表示
No.5
- 回答日時:
#3さんのコードはきれいだけど、再帰を使ったりしてちょっと高度なので、オーソドックスなコードを。
最初のFor文の箇所だけ書いておきます。
for(i = 2; i <= MAX; i++){
sum[i] = 0;
n = i;
j = 2;
while(j * j <= n){
if(n % j == 0){
sum[i] += j;
n /= j;
}
else
j++;
}
sum[i] += n;
}
No.3
- 回答日時:
プログラムなんて100人いれば100通りの書き方があるのだから、コメントも何も無くて何を意図しようとした構造なのかわからない穴埋め問題なんて解読が面倒でやってられないので、とりあえず同じ機能を実現するものを作ってみまちた。
#include <stdio.h>
#define MAX 20000
// 素因数の合計を求める
int SumOfPrimeFactor(int num)
{
int i;
for (i = 2; i < num; i++) {
if (num % i == 0) {
return(i + SumOfPrimeFactor(num / i));
}
}
return(num);
}
// MAXまでの隣接する数値の素因数の合計が等しい組み合わせを探す
void main()
{
int sum1 = -1;
int sum2 = 0;
int cnt = 0;
for (i = 2; i <= MAX; i++) {
sum2 = SumOfPrimeFactor(i);
if (sum2 == sum1) {
cnt++;
printf("%3d (%d, %d)\n", cnt, i - 1, i);
}
sum1 = sum2;
}
}
No.1
- 回答日時:
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# c言語の問題です 3 2023/01/10 16:15
- C言語・C++・C# C言語階乗の総和を求める 2 2023/03/04 23:31
- C言語・C++・C# C言語 3 2022/11/09 13:27
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
- C言語・C++・C# c言語 プログラムのエラー 1 2023/02/11 20:31
- C言語・C++・C# C言語プログラム変更 2 2022/12/21 15:03
- C言語・C++・C# プログラミングを教えて欲しいです。 配列aは、int a[9]={7,6,12,8,3,5,10,9 4 2022/12/19 23:27
- C言語・C++・C# C言語 プログラミング 4 2022/05/22 11:53
- C言語・C++・C# C言語 3 2022/10/04 15:07
- C言語・C++・C# 至急教えてください。プログラミングの問題です。 最初に正の整数nの入力を受け付け、次に分数の分子と分 1 2022/07/19 17:03
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・ハマっている「お菓子」を教えて!
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
2の補数を計算するプログラム
-
intとlongは同じ?
-
再起呼び出しの回数をカウント...
-
C言語で%を使わない余りの出し方
-
カードシャッフルのブログラム...
-
OpenCVによる4値化について
-
C++で表を作成したいのです ...
-
分数の足し算をさせるプログラ...
-
条件が多い場合
-
画像の拡大・縮小
-
ヌメロンのプログラム
-
C言語で簡単なパックマンゲーム...
-
C++ bmp 透過処理
-
関数とビット列
-
コマンドプロンプトのウィンド...
-
3のつく数と3の倍数を表示 C言語
-
異なるn個の整数からr個の整数...
-
迷路を脱出する経路探索プログ...
-
whileとifを使い偶数を出すには
-
再帰処理をループ処理に変換
おすすめ情報