blog/content/post/2009/05/17/2009-05-17-00001157.md

121 lines
7.7 KiB
Markdown

---
title: 文字列の扱い
author: kazu634
date: 2009-05-17
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:4599;}s:9:"hash_tags";a:0:{}s:8:"accounts";a:1:{i:0;s:7:"kazu634";}}'
categories:
- C
---
<div class="section">
<p>
<a href="http://d.hatena.ne.jp/asin/4320026926" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://d.hatena.ne.jp/asin/4320026926', 'プログラミング言語C 第2版 ANSI規格準拠');">プログラミング言語C 第2版 ANSI規格準拠</a>』の練習問題を解いていました:
</p>
<blockquote>
<p>
文字列s2中の任意の文字に等しい文字をslから除去するような形のsqueeze(sl, s2)を書け。
</p>
</blockquote>
<pre class="syntax-highlight">
<span class="synPreProc">#include </span><span class="synConstant">&#60;stdio.h&#62;</span>
<span class="synComment">/* prototype declarations */</span>
<span class="synType">void</span> squeeze(<span class="synType">char</span> source[], <span class="synType">char</span> target[], <span class="synType">int</span> num);
<span class="synType">int</span> count_char(<span class="synType">char</span> target[]);
<span class="synComment">/* program begins here */</span>
<span class="synType">int</span> main(<span class="synType">int</span> argc, <span class="synType">char</span> *argv[]) {
<span class="synType">char</span> source[] = <span class="synConstant">&#34;12345123451234567890&#34;</span>;
<span class="synType">char</span> test[] = <span class="synConstant">&#34;1278&#34;</span>;
squeeze(source, test, count_char(test));
printf(<span class="synConstant">&#34;</span><span class="synSpecial">%s\n</span><span class="synConstant">&#34;</span>, source);
<span class="synStatement">return</span> <span class="synConstant"></span>;
}
<span class="synType">void</span> squeeze(<span class="synType">char</span> source[], <span class="synType">char</span> target[], <span class="synType">int</span> num)
{
<span class="synType">int</span> i; <span class="synComment">/* sourceの添え字 (before update) */</span>
<span class="synType">int</span> j; <span class="synComment">/* sourceの添え字 (after update) */</span>
<span class="synType">int</span> k; <span class="synComment">/* index of target */</span>
<span class="synType">int</span> flag; <span class="synComment">/* flag */</span>
<span class="synStatement">for</span> (i = j = <span class="synConstant"></span>; source[i] != <span class="synSpecial">'\0'</span>; i++)
{
flag = <span class="synConstant"></span>;
<span class="synStatement">for</span> (k = <span class="synConstant"></span>; k &#60; num; k++)
{
<span class="synStatement">if</span> (source[i] == target[k]){
flag = <span class="synConstant">1</span>;
<span class="synStatement">break</span>;
} <span class="synStatement">else</span> {
flag = <span class="synConstant"></span>;
}
}
<span class="synStatement">if</span> (flag == <span class="synConstant"></span>){
source[j++] = source[i];
}
}
source[j] =<span class="synSpecial">'\0'</span>;
}
<span class="synType">int</span> count_char(<span class="synType">char</span> target[])
{
<span class="synType">int</span> i; <span class="synComment">/* working variable */</span>
<span class="synType">int</span> num = <span class="synConstant"></span>; <span class="synComment">/* Number of chars */</span>
<span class="synStatement">for</span> (i = <span class="synConstant"></span>; target[i] != <span class="synSpecial">'\0'</span>; i++)
{
num++;
}
<span class="synStatement">return</span> num;
}
</pre>
<h4>
<a href="http://d.hatena.ne.jp/asin/4320026926" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://d.hatena.ne.jp/asin/4320026926', 'プログラミング言語C 第2版 ANSI規格準拠');">プログラミング言語C 第2版 ANSI規格準拠</a>」に関連する最近のエントリ
</h4>
<ul>
<li>
<a href="http://d.hatena.ne.jp/sirocco634/20090513/1242221430" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://d.hatena.ne.jp/sirocco634/20090513/1242221430', ' 16進数を10進数に変換する関数の作成 &#8211; 武蔵の日記');" target="_blank"> 16進数を10進数に変換する関数の作成 &#8211; 武蔵の日記</a>
</li>
<li>
<a href="http://d.hatena.ne.jp/sirocco634/20090512/1242140262" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://d.hatena.ne.jp/sirocco634/20090512/1242140262', ' 16進数を10進数に変換する &#8211; 武蔵の日記');" target="_blank"> 16進数を10進数に変換する &#8211; 武蔵の日記</a>
</li>
<li>
<a href="http://d.hatena.ne.jp/sirocco634/20090510/1241924398" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://d.hatena.ne.jp/sirocco634/20090510/1241924398', ' C言語での引数の扱い &#8211; 武蔵の日記');" target="_blank"> C言語での引数の扱い &#8211; 武蔵の日記</a>
</li>
</ul>
<div class="hatena-asin-detail">
<a href="http://www.amazon.co.jp/dp/4320026926/?tag=hatena_st1-22&ascsubtag=d-7ibv" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://www.amazon.co.jp/dp/4320026926/?tag=hatena_st1-22&ascsubtag=d-7ibv', '');"><img src="https://images-na.ssl-images-amazon.com/images/I/41W69WGATNL._SL160_.jpg" class="hatena-asin-detail-image" alt="プログラミング言語C 第2版 ANSI規格準拠" title="プログラミング言語C 第2版 ANSI規格準拠" /></a></p>
<div class="hatena-asin-detail-info">
<p class="hatena-asin-detail-title">
<a href="http://www.amazon.co.jp/dp/4320026926/?tag=hatena_st1-22&ascsubtag=d-7ibv" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://www.amazon.co.jp/dp/4320026926/?tag=hatena_st1-22&ascsubtag=d-7ibv', 'プログラミング言語C 第2版 ANSI規格準拠');">プログラミング言語C 第2版 ANSI規格準拠</a>
</p>
<ul>
<li>
<span class="hatena-asin-detail-label">作者:</span> <a href="http://d.hatena.ne.jp/keyword/B%2EW%2E%A5%AB%A1%BC%A5%CB%A5%CF%A5%F3" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://d.hatena.ne.jp/keyword/B%2EW%2E%A5%AB%A1%BC%A5%CB%A5%CF%A5%F3', 'B.W.カーニハン');" class="keyword">B.W.カーニハン</a>,<a href="http://d.hatena.ne.jp/keyword/D%2EM%2E%A5%EA%A5%C3%A5%C1%A1%BC" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://d.hatena.ne.jp/keyword/D%2EM%2E%A5%EA%A5%C3%A5%C1%A1%BC', 'D.M.リッチー');" class="keyword">D.M.リッチー</a>,<a href="http://d.hatena.ne.jp/keyword/%C0%D0%C5%C4%C0%B2%B5%D7" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://d.hatena.ne.jp/keyword/%C0%D0%C5%C4%C0%B2%B5%D7', '石田晴久');" class="keyword">石田晴久</a>
</li>
<li>
<span class="hatena-asin-detail-label">出版社/メーカー:</span> <a href="http://d.hatena.ne.jp/keyword/%B6%A6%CE%A9%BD%D0%C8%C7" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://d.hatena.ne.jp/keyword/%B6%A6%CE%A9%BD%D0%C8%C7', '共立出版');" class="keyword">共立出版</a>
</li>
<li>
<span class="hatena-asin-detail-label">発売日:</span> 1989/06/15
</li>
<li>
<span class="hatena-asin-detail-label">メディア:</span> 単行本
</li>
<li>
<span class="hatena-asin-detail-label">購入</span>: 28人 <span class="hatena-asin-detail-label">クリック</span>: 721回
</li>
<li>
<a href="http://d.hatena.ne.jp/asin/4320026926" onclick="__gaTracker('send', 'event', 'outbound-article', 'http://d.hatena.ne.jp/asin/4320026926', 'この商品を含むブログ (206件) を見る');" target="_blank">この商品を含むブログ (206件) を見る</a>
</li>
</ul>
</div>
<div class="hatena-asin-detail-foot">
</div>
</div>
</div>