blog/content/post/2008/05/06/2008-05-06-00000910.md

195 lines
8.9 KiB
Markdown
Raw Normal View History

2019-03-31 11:00:21 +00:00
---
title: 『新版 C言語によるアルゴリズムとデータ構造』のつづき
author: kazu634
date: 2008-05-06
url: /2008/05/06/_979/
wordtwit_post_info:
- 'O:8:"stdClass":13:{s:6:"manual";b:0;s:11:"tweet_times";i:1;s:5:"delay";i:0;s:7:"enabled";i:1;s:10:"separation";s:2:"60";s:7:"version";s:3:"3.7";s:14:"tweet_template";b:0;s:6:"status";i:2;s:6:"result";a:0:{}s:13:"tweet_counter";i:2;s:13:"tweet_log_ids";a:1:{i:0;i:3985;}s:9:"hash_tags";a:0:{}s:8:"accounts";a:1:{i:0;s:7:"kazu634";}}'
categories:
- C
- Programming
---
<div class="section">
<p>
 続きだよ。
</p>
<div class="hatena-asin-detail">
<a href="http://www.amazon.co.jp/dp/4797331631/?tag=hatena_st1-22&ascsubtag=d-7ibv" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://www.amazon.co.jp/dp/4797331631/?tag=hatena_st1-22&ascsubtag=d-7ibv', '');"><img src="https://images-na.ssl-images-amazon.com/images/I/51HCG5croYL._SL160_.jpg" class="hatena-asin-detail-image" alt="新版 C言語によるアルゴリズムとデータ構造" title="新版 C言語によるアルゴリズムとデータ構造" /></a></p>
<div class="hatena-asin-detail-info">
<p class="hatena-asin-detail-title">
<a href="http://www.amazon.co.jp/dp/4797331631/?tag=hatena_st1-22&ascsubtag=d-7ibv" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://www.amazon.co.jp/dp/4797331631/?tag=hatena_st1-22&ascsubtag=d-7ibv', '新版 C言語によるアルゴリズムとデータ構造');">新版 C言語によるアルゴリズムとデータ構造</a>
</p>
<ul>
<li>
<span class="hatena-asin-detail-label">作者:</span> <a href="http://d.hatena.ne.jp/keyword/%BC%C6%C5%C4%CB%BE%CD%CE" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://d.hatena.ne.jp/keyword/%BC%C6%C5%C4%CB%BE%CD%CE', '柴田望洋');" class="keyword">柴田望洋</a>,<a href="http://d.hatena.ne.jp/keyword/%C4%D4%CE%BC%B2%F0" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://d.hatena.ne.jp/keyword/%C4%D4%CE%BC%B2%F0', '辻亮介');" class="keyword">辻亮介</a>
</li>
<li>
<span class="hatena-asin-detail-label">出版社/メーカー:</span> <a href="http://d.hatena.ne.jp/keyword/%A5%BD%A5%D5%A5%C8%A5%D0%A5%F3%A5%AF%A5%AF%A5%EA%A5%A8%A5%A4%A5%C6%A5%A3%A5%D6" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://d.hatena.ne.jp/keyword/%A5%BD%A5%D5%A5%C8%A5%D0%A5%F3%A5%AF%A5%AF%A5%EA%A5%A8%A5%A4%A5%C6%A5%A3%A5%D6', 'ソフトバンククリエイティブ');" class="keyword">ソフトバンククリエイティブ</a>
</li>
<li>
<span class="hatena-asin-detail-label">発売日:</span> 2005/08/27
</li>
<li>
<span class="hatena-asin-detail-label">メディア:</span> 大型本
</li>
<li>
<span class="hatena-asin-detail-label">購入</span>: 4人 <span class="hatena-asin-detail-label">クリック</span>: 14回
</li>
<li>
<a href="http://d.hatena.ne.jp/asin/4797331631" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://d.hatena.ne.jp/asin/4797331631', 'この商品を含むブログ (23件) を見る');" target="_blank">この商品を含むブログ (23件) を見る</a>
</li>
</ul>
</div>
<div class="hatena-asin-detail-foot">
</div>
</div>
<p>
<a name="seemore"></a>
</p>
<h4>
for の挙動
</h4>
<p>
 例題としてあげられているプログラムの読み方でちょっととまどった。
</p>
<pre class="syntax-highlight">
<span class="synPreProc">#include </span><span class="synConstant">&#60;stdio.h&#62;</span>
<span class="synType">int</span> main(<span class="synType">void</span>);
<span class="synType">int</span> main(<span class="synType">void</span>)
{
<span class="synType">int</span> i, n;
<span class="synType">unsigned</span> <span class="synType">long</span> counter = <span class="synConstant"></span>;
<span class="synStatement">for</span> (n = <span class="synConstant">2</span>;n &#60;= <span class="synConstant">1000</span>;n++) {
<span class="synStatement">for</span> (i = <span class="synConstant">2</span>;i &#60; n;i++) {
counter++;
<span class="synStatement">if</span> (<span class="synConstant"></span> == n % i) <span class="synStatement">break</span>;
}
<span class="synStatement">if</span> (n == i) printf (<span class="synConstant">&#34;</span><span class="synSpecial">%d\n</span><span class="synConstant">&#34;</span>, n);
}
printf (<span class="synConstant">&#34;除算を行った回数: </span><span class="synSpecial">%lu\n</span><span class="synConstant">&#34;</span>, counter);
<span class="synStatement">return</span>(<span class="synConstant"></span>);
}
</pre>
<p>
これは
</p>
<blockquote title="Amazon.co.jp 新版 C言語によるアルゴリズムとデータ構造: 柴田 望洋, 辻 亮介: 本" cite="https://www.amazon.co.jp/exec/obidos/ASIN/4797331631/simsnes-22/ref=nosim">
<p>
ある整数nは、2からn-1までの、いずれの整数で割り算を行っても、割り切れなければ素数です。
</p>
<p>
<cite><a href="https://www.amazon.co.jp/exec/obidos/ASIN/4797331631/simsnes-22/ref=nosim" onclick="__gaTracker('send', 'event', 'outbound-article', 'https://www.amazon.co.jp/exec/obidos/ASIN/4797331631/simsnes-22/ref=nosim', 'Amazon CAPTCHA');" target="_blank">Amazon CAPTCHA</a></cite>
</p>
</blockquote>
<p>
という発想で書かれているそうなんだけれど、
</p>
<pre class="syntax-highlight">
<span class="synStatement">for</span> (n = <span class="synConstant">2</span>;n &#60;= <span class="synConstant">1000</span>;n++) {
<span class="synStatement">for</span> (i = <span class="synConstant">2</span>;i &#60; n;i++) {
counter++;
<span class="synStatement">if</span> (<span class="synConstant"></span> == n % i) <span class="synStatement">break</span>;
}
<span class="synStatement">if</span> (n == i) printf (<span class="synConstant">&#34;</span><span class="synSpecial">%d\n</span><span class="synConstant">&#34;</span>, n);
}
</pre>
<p>
の部分の内側のforがbreakせずに終了するときにはi++するからn=iになっていると言われて、なるへそと思ってしまった。そういえばforって、i++して条件式i < nを満たしているかを確認する命令でしたね失礼しました(__)
</p>
<h4>
配列の添え字指定をするときのインクリメントの挙動がわからない!
</h4>
<p>
 さっきのを
</p>
<ul>
<li>
偶数は2で割り切れるんだから、考えるだけ無駄
</li>
<li>
素数になるのは結局それ以前に素数だと判明した数字で割り切れなければいいんでしょ!
</li>
</ul>
<p>
みたいな発想で
</p>
<p>
</p>
<pre class="syntax-highlight">
<span class="synPreProc">#include </span><span class="synConstant">&#60;stdio.h&#62;</span>
<span class="synType">int</span> main(<span class="synType">void</span>);
<span class="synType">int</span> main(<span class="synType">void</span>)
{
<span class="synType">int</span> i, n;
<span class="synType">int</span> prime[<span class="synConstant">500</span>];
<span class="synType">int</span> ptr = <span class="synConstant"></span>;
<span class="synType">unsigned</span> <span class="synType">long</span> counter = <span class="synConstant"></span>;
prime[ptr++] = <span class="synConstant">2</span>;
prime[ptr++] = <span class="synConstant">3</span>;
<span class="synStatement">for</span> (n = <span class="synConstant">5</span>;n &#60;= <span class="synConstant">1000</span>;n +=<span class="synConstant">2</span>) {
<span class="synStatement">for</span> (i = <span class="synConstant">1</span>;i &#60; ptr;i++) {
counter++;
<span class="synStatement">if</span> (<span class="synConstant"></span> == n % prime[i])
<span class="synStatement">break</span>;
}
<span class="synStatement">if</span> (ptr == i) prime[ptr++] = n;
}
<span class="synStatement">for</span> (i = <span class="synConstant"></span>;i &#60; ptr;i++)
printf (<span class="synConstant">&#34;</span><span class="synSpecial">%d\n</span><span class="synConstant">&#34;</span>, prime[i]);
printf (<span class="synConstant">&#34;除算を行った回数: </span><span class="synSpecial">%lu\n</span><span class="synConstant">&#34;</span>, counter);
<span class="synStatement">return</span>(<span class="synConstant"></span>);
}
</pre>
<p>
これなんだけど、最初の「prime[ptr++] = 2;」の挙動が分からない(..;)どうやら
</p>
<pre class="syntax-highlight">
<span class="synType">int</span> ptr = <span class="synConstant"></span>;
prime[ptr] = <span class="synConstant">2</span>;
ptr++;
prime[ptr] = <span class="synConstant">3</span>;
ptr++;
</pre>
<p>
しているような雰囲気なんだけど、それで果たして良いのか?が疑問。
</p>
<h4>
コンマ演算子
</h4>
<blockquote>
<p>
コンマ演算子を用いたコンマ式「operation1, operation2」を評価すると、式operation1とopeation2が順に評価され、この式全体としては後で評価されたoperation2の型と値になります。
</p>
</blockquote>
<p>
だそうです。
</p>
</div>