121 lines
7.7 KiB
Markdown
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"><stdio.h></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">"12345123451234567890"</span>;
|
||
|
<span class="synType">char</span> test[] = <span class="synConstant">"1278"</span>;
|
||
|
squeeze(source, test, count_char(test));
|
||
|
printf(<span class="synConstant">"</span><span class="synSpecial">%s\n</span><span class="synConstant">"</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 < 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進数に変換する関数の作成 – 武蔵の日記');" target="_blank"> 16進数を10進数に変換する関数の作成 – 武蔵の日記</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進数に変換する – 武蔵の日記');" target="_blank"> 16進数を10進数に変換する – 武蔵の日記</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言語での引数の扱い – 武蔵の日記');" target="_blank"> C言語での引数の扱い – 武蔵の日記</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>
|