質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.37%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

Q&A

解決済

2回答

958閲覧

線形探索アルゴリズムの正当性、停止性の証明

egpro

総合スコア5

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

0グッド

0クリップ

投稿2021/06/19 04:58

前提・実現したいこと

teratail初心者のため失礼がありましたら申し訳ございません。
院試の勉強をしており、以下の線形探索アルゴリズムの正当性、停止性を証明して頂きたいです。

該当のソースコード

C

1#include <stdio.h> 2#define N 9 /*探している値*/ 3 4int main(void){ 5 int a[10]={3,10,4,5,6,1,8,7,9,2}; 6 int number=sizeof(a)/sizeof(int); 7 8 int i; 9 10 for(i=0; i<number; i++){ 11 if(N==a[i]){ 12 printf("%d番目に見つかりました\n", i+1); 13 return 0; 14 } 15 } 16 printf("見つかりませんでした\n"); 17 return 0; 18} 19

試したこと

停止性の自分で出した証明↓↓↓
forの繰り返しはi=numberになったらループを抜けるため、このプログラムは停止する。

正当性はわからないので教えて頂きたいです。停止性もこんな単純でいいのかと不安です。
よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

  • 以下の線形探索アルゴリズムの正当性、停止性を証明して頂きたいです。

停止性の証明はegproが書かれていることで概ねあっています。
厳密にいえば、for文の本体であるブロックの中で変数iの更新がないことを明記しておけばよろしいでしょう。

正当性の証明はできません。
その理由は、「仕様」が書かれていないからです。

もしも、このプログラムの仕様が

「9番目に見つかりました」と表示した後で改行する」

であれば正当です。ただし、

C

1#include <stdio.h> 2int main(void){ 3 printf("9番目に見つかりました\n"); 4} 5

も同じように正当です。

もしも、このプログラムの仕様が

任意の長さの整数配列から指定した整数と一致する要素がある場合に、その要素の最も小さいインデックス+1を使って「番目に見つかりました」と表示した後で改行する。
一致する要素があるない場合は「、見つかりませんでした」と表示した後で改行する。

であれば、正当ではありません。
それは、整数配列の要素が2147483649以上であったり、配列の長さが2147483649以上である場合は仕様通りに動作しないからです。

投稿2021/06/21 00:28

ppaul

総合スコア24668

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

私は趣味&独学なので詳しくはわかりません。

ですが、『アルゴリズム 正当性 証明』でggると、こちらがヒットしました。

上記を読むに、『実際のデータを入れてみて、本来の結果になるか』を流れでやってみるだけのようです。

[例] n = 1のとき、int x = 3 * n + 1は 3×1×1=3 n = 2 のとき、... したがってこのアルゴリズムは正当である。

的な感じでは?

(上記はあくまで例。もっとましなフォーマットがあればそれに従うべきですね。私は無学なので)

投稿2021/06/19 06:17

BeatStar

総合スコア4962

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.37%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問