タイトルにあるプログラムを書いたときに,予期せぬ結果になってしまうので,
どこがどのように違うのか,どうすればよいのかを教えていただきたいです.
申し訳ないのですが見ていただけたら嬉しいです.
コンパイルでエラーはでません.
文字数が足りないので,求める結果と現在の結果は補足に載せます.
以下,ソースコード
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#define N 5 /* 都市の数 */
/* 都市の座標構造体 */
struct City{
int x, y;
};
/* 問題情報構造体 */
struct TSP {
struct City city[N]; /* 都市の位置 */
int currentOrder[N];
int changedOrder[N]; /* 巡回順 */
float currentCost;
float changedCost; /* 総移動距離 */
};
/* 関数の宣言 */
void ReadData(struct TSP *tsp);
void ShowData(struct TSP *tsp);
void TwoOpt(const int currentOrder[N], int changedOrder[N], int x1, int x2);
float CalcDistance(struct City a, struct City b);
void currentOrder(struct TSP *tsp);
void CalcCost(struct TSP *tsp);
int UpdateOrder(struct TSP *tsp, int x1, int x2);
void ShowCost(struct TSP *tsp);
/*
* メイン関数
*/
int main()
{
struct TSP tsp;
ReadData(&tsp);
ShowData(&tsp);
currentOrder(&tsp);
ShowCost(&tsp);
return 0;
}
/*
* 都市座標データ読み込み
*/
void ReadData(struct TSP *tsp)
{
/* ファイルオープン */
FILE* fp = fopen("cities05.csv", "r");
if (fp == NULL) {
printf("Can't open data file.\n");
}
/* データ読み込み */
int i;
for (i = 0; i < N; i++) {
fscanf(fp, "%d,%d\n", &tsp->city[i].x, &tsp->city[i].y);
}
fclose(fp);
}
/*
* 都市座標データ表示
*/
void ShowData(struct TSP *tsp)
{
int i;
/* データ表示 */
printf("Cities location:\n");
for (i = 0; i < N; i ++) {
printf("C%-2d : %4d,%4d\n", i + 1, tsp->city[i].x, tsp->city[i].y);
}
}
/*
* 2-opt関数
*/
void TwoOpt(const int currentOrder[N], int changedOrder[N], int x1, int x2)
{
int i = 0;
while(1){
if(currentOrder[x1+i] == currentOrder[x2-i]){
changedOrder[x1+i] = currentOrder[x1+i];
break;
}
else{
changedOrder[x2-i] = currentOrder[x1+i];
changedOrder[x1+i] = currentOrder[x2-i];
i++;
}
}
for(i = 1; i<=x1; i++){
changedOrder[x1-i] = currentOrder[x1-i];
}
for(i = 1; i<=N-x2-1; i++){
changedOrder[x2+i] = currentOrder[x2+i];
}
}
/*
*現在の巡回順
*/
void currentOrder(struct TSP *tsp)
{
int currentOrder[N];
int i;
for (i = 0; i < N; i++) {
currentOrder[i] = i;
}
}
/*
* 総移動距離を計算する
*/
void CalcCost(struct TSP *tsp)
{
int i;
tsp->currentCost = 0;
for (i = 0; i < N; i++) {
if(i == N-1){
tsp->currentCost += CalcDistance(tsp->city[tsp->currentOrder[i]], tsp->city[tsp->currentOrder[0]]);
}
else{
tsp->currentCost += CalcDistance(tsp->city[tsp->currentOrder[i]], tsp->city[tsp->currentOrder[i+1]]);
}
}
tsp->changedCost = 0;
for (i = 0; i < N; i++) {
if(i == N-1){
tsp->changedCost += CalcDistance(tsp->city[tsp->changedOrder[i]], tsp->city[tsp->changedOrder[0]]);
}
else{
tsp->changedCost += CalcDistance(tsp->city[tsp->changedOrder[i]], tsp->city[tsp->changedOrder[i+1]]);
}
}
}
/*
* 2都市間の距離を計算
* 引数:struct City a : 都市1
* 引数:struct City b : 都市2
* 戻り値:距離
*/
float CalcDistance(struct City a, struct City b)
{
float distance;
distance += sqrt(pow((a.x - b.x), 2) + pow((a.y - b.y), 2));
return distance;
}
/*
* 巡回順と総移動距離を表示
*/
void ShowCost(struct TSP *tsp)
{
int i;
int x1, x2;
int currentOrder[N], changedOrder[N];
/* x1, x2 のキーボード入力 */
printf("Please enter x1 and x2\n");
printf("x1 = ");
scanf("%d", &x1);
printf("x2 = ");
scanf("%d", &x2);
printf("Current order: ");
for (i = 0; i < N; i ++) {
printf("C%-2d> ", currentOrder[i] + 1);
}
printf("C%-2d Current cost = %7.1f\n", currentOrder[0] + 1, tsp->currentCost);
TwoOpt(currentOrder, changedOrder, x1, x2);
printf("Changed order: ");
for(i = 0; i < N; i ++) {
printf("C%-2d> ", changedOrder[i] + 1);
}
printf("C%-2d Changed cost = %7.1f\n", changedOrder[0] + 1, tsp->changedCost);
}
A 回答 (5件)
- 最新から表示
- 回答順に表示
No.5
- 回答日時:
「2つ目」の方はちょくちょくやらかすやつがいる. ただ, 冷静になって考えてほしいんだが,
tsp->currentOrder[N]
ってなにかおかしいと思わない?
「1つ目」は正直
なにをどう考えてそう書いたのか
がわかんない. そういう書き方, どこにありました?
あ, TSP って構造体のメンバー, どういう意味を持たせてます?
No.4
- 回答日時:
その関数についてはそんなふう. 他にも直すべきところはあるけどね.
なるほど!ありがとうございます.
早速直してみたのですが,コンパイルしたとき,3つエラーが出る場所がありました.
どう改善すればよいのかわからなかったので,申し訳ないのですが教えていただけないでしょうか.
1つ目のは,全く見当がつきません.
2つ目は,
void ShowCost
の部分の
TwoOpt
の()内の始め2つの引数の型が違うと言われていると思っています.
tsp.currentOrder[N]
など試したのですが,
どう変えればいいのか教えていただけませんか.
以下,エラー内容になります.
1つ目
error: expected ‘;’, ‘,’ or ‘)’ before ‘->’ token
void TwoOpt(const int tsp->currentOrder[N], int tsp->changedOrder[N], int x1, int x2)
2つ目
In function ‘ShowCost’:
warning: passing argument 1 of ‘TwoOpt’ makes pointer from integer without a cast [-Wint-conversion]
TwoOpt(tsp->currentOrder[N], tsp->changedOrder[N], x1, x2);
| ~~~~~~~~~~~~~~
| |
| int
note: expected ‘const int *’ but argument is of type ‘int’
void TwoOpt(const int currentOrder[N], int changedOrder[N], int x1, int x2);
3つめは2つ目に似ていて,次数が足りないので省略させていただきます.
恐れ入りますが,お返事いただければ幸いです.
No.3
- 回答日時:
そんなことは聞いていない.
「引数」がなにか, わかっていますか?
ちなみに同じようなミスを他にも数カ所でしてる.
お返事ありがとうございます。
引数についてですが、以下のプログラムだとしたら、
*tspの部分で、
関数内で*tspが出てきたら、他の関数からこの部分を代入(?)する、という感じだと思っています。
void currentOrder(struct TSP *tsp)
{
int currentOrder[N];
int i;
for (i = 0; i < N; i++) {
currentOrder[i] = i;
}
}
考えてみたのですが、以下のようにする、ということでしょうか。
void currentOrder(struct TSP *tsp)
{
int i;
for (i = 0; i < N; i++) {
tsp->currentOrder[i] = i;
}
}
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# c言語の問題です 3 2023/01/10 16:15
- C言語・C++・C# プログラミング c言語 4 2023/03/07 01:05
- C言語・C++・C# C言語の課題が出たのですが自力でやっても分かりませんでした。 要素数がnであるint型の配列v2の並 3 2022/11/19 17:41
- C言語・C++・C# 未解決の外部シンボル _printfが関数_mainで参照されました 1 2022/09/18 15:28
- C言語・C++・C# カードシャッフルのブログラムを使ってc言語でブラックジャックをしたい 2 2022/04/12 15:13
- C言語・C++・C# プログラミングの授業の課題です 1 2023/01/17 22:15
- C言語・C++・C# C言語 プログラミング 4 2022/05/22 11:53
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
- C言語・C++・C# c言語配列の結合についてです。 なぜうまくいかないのでしょうか。 #include <stdio.h 4 2022/05/30 22:42
- 大学・短大 C言語線形リストの問題です 3 2022/12/22 00:45
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・「みんな教えて! 選手権!!」開催のお知らせ
- ・漫画をレンタルでお得に読める!
- ・「これいらなくない?」という慣習、教えてください
- ・今から楽しみな予定はありますか?
- ・AIツールの活用方法を教えて
- ・【選手権お題その3】この画像で一言【大喜利】
- ・【お題】逆襲の桃太郎
- ・自分独自の健康法はある?
- ・最強の防寒、あったか術を教えてください!
- ・【大喜利】【投稿~1/9】 忍者がやってるYouTubeが炎上してしまった理由
- ・歳とったな〜〜と思ったことは?
- ・ちょっと先の未来クイズ第6問
- ・モテ期を経験した方いらっしゃいますか?
- ・好きな人を振り向かせるためにしたこと
- ・【選手権お題その2】この漫画の2コマ目を考えてください
- ・【選手権お題その1】これってもしかして自分だけかもしれないな…と思うあるあるを教えてください
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
std::set<int> で、ある値が何...
-
C言語での引数の省略方法
-
C言語 エラーの原因がわからな...
-
並列プログラミングのπ計算につ...
-
ラップ関数とはどんなものですか?
-
足して100になるような乱数のア...
-
未解決の外部シンボル _printf...
-
実数の整数部,小数部の取得
-
毎回違う乱数を生成するにはど...
-
if と配列の組み合わせ
-
Win32APIで作るコンボボックス...
-
組み合わせ順列
-
C言語の配列をC++のvectorに高...
-
C言語の基礎 . 2乗値の差につ...
-
VB.NET DLL 参照型String読込み
-
可変長配列の初期化
-
下記プログラムのフローチャー...
-
配列を使って複数の線分を描く...
-
c言語 〇×ゲーム
-
C言語<素数を求めるプログラム>
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「指定されたキャストは有効で...
-
C言語での引数の省略方法
-
C言語 エラーの原因がわからな...
-
#define _CRT_SECURE_NO_WARNIN...
-
複数桁10進数の*桁目だけを抽出...
-
【C++】関数ポインタの使い方
-
ラップ関数とはどんなものですか?
-
ColorをRGBで指定する方法
-
(int *)の意味
-
足して100になるような乱数のア...
-
シェルピンスキーのギャスケット
-
if と配列の組み合わせ
-
実数の整数部,小数部の取得
-
構造体の勉強中です 合計点の高...
-
「{ } で囲むだけ」は正しい?
-
c言語の配列を使ってサイコロを...
-
式は定数値が必要です」という...
-
acceptをalarmでタイムアウトさ...
-
read関数をノンブロッキングで...
-
std::set<int> で、ある値が何...
おすすめ情報
以下,現在の実行結果
Cities location:
C1 : 63, 95
C2 : 88, 48
C3 : 51, 21
C4 : 41, 64
C5 : 3, 32
Please enter x1 and x2
x1 = 2
x2 = 4
Current order: C-2051296927> C32622> C-524644367> C32768> C1 > C-2051296927 Current cost = -107548773851374551040.0
Changed order: C-2051296927> C32622> C1 > C32768> C-524644367> C-2051296927 Changed cost = 0.0
Segmentation fault (core dumped)
以下,求める実行結果
Current order: , Changed order: のところは,全ての都市を一回ずつ回るようにしたいです.
Cities location:
C1 : 63, 95
C2 : 88, 48
C3 : 51, 21
C4 : 41, 64
C5 : 3, 32
Please enter x1 and x2
x1 = 2
x2 = 4
Current order: C1> C2> C3> C4> C5 > C1 Current cost= 279.9
Changed order: C1> C4> C5 > C3> C2> C1 Changed cost = 236.0