「みんな教えて! 選手権!!」開催のお知らせ

文字列「abc」の各アルファベットを1文字ずらすと文字列「bcd
」になり、
文字列「nisidate」の各アルファベットを2文字ずらすと文字
列「pkukfcvg」となる。さらに、
文字列「kibishii」の各アルファベットを2文字ずらすと文字
列「mkdkujkk」となる。
このような、任意の文字列の各要素を任意の文字数ずらすプロ
グラムを作成する、なお、zを1文字ずらしたとき
のアルファベットはaとする。

#include <stdio.h>
#include <string.h>

int main(void)
{
char str[27]="abcdefghijklmnopqrstuvwxyz",str1[50], str2[50];
int x,i,j,len;

printf("文字列を入力---> ");
scanf("%s", str1);

printf("何文字ずらすかを入力---> ");
scanf("%d",&x);

len=strlen(str1);

for(i=0;i<len;i++)
{
for(j=0;j<27;j++)
{
if(str1[i]=='z')
{
str2[i]=str[x-1];
}
if(!(str1[i]=='z'))
{
if(str1[i]==str[j])
{
str2[i]=str[j+x];
}
}
}
}

printf("%d文字ずらした文字列は%sです\n", x, str2);

return 0;

よろしくお願いします!!

A 回答 (5件)

#3です。


指摘だけでも、不親切なので。
以下、模範解答。
修正点は以下の通り。
ずらしの文字は、右側だけだが、左側にも対応。(左側の場合、マイナスの値を指定)
ずらじの文字数が、26以上でも対応する。2600のずらし等もOK。
zの文字のみを特殊な扱いにしない。yを2文字ずらして、aになるようにする。
以下ソース。
---------------------------------------------
#include <stdio.h>
#include <string.h>
//shfit_count :ずらし数(26以上を許す)負の数でも良い
//char_in :入力文字(1文字)
//戻り値:ずらした結果の1文字
char shift_char(int shift_count,char char_in)
{
char str[27] = "abcdefghijklmnopqrstuvwxyz";
int i,j;
//入力文字の位置を検索
for (i = 0; i < 26; i++){
if (char_in == str[i]) break;
}
//入力文字がa~z以外ならaとみなす
if (i == 26) i = 0;
//ずらした後の文字の位置を求める。26の余りを求めるのは、26以上のずらしに対応するため
j = (i + shift_count)%26;
//左へのずらしに対応する
if (j < 0) {
j += 26;
}
//これで 0<=j<=25であることが保証されるので、この位置の文字を返す
return str[j];
}
int main(void)
{
char str[27]="abcdefghijklmnopqrstuvwxyz",str1[50], str2[50];
int x,i,j,len;

printf("文字列を入力---> ");
scanf("%s", str1);

printf("何文字ずらすかを入力---> ");
scanf("%d",&x);

len=strlen(str1);

for(i=0;i<len;i++)
{
str2[i] = shift_char(x,str1[i]);
}
//終端にNULLを付加する
str2[i] = '\0';
printf("%d文字ずらした文字列は%sです\n", x, str2);

return 0;
}
--------------------------------------------------------
    • good
    • 0
この回答へのお礼

勉強になりました、
詳しくて教えてこころより感謝します!

お礼日時:2008/07/18 13:07

#include <stdio.h>



void shift(const char *s1, char *s2, int n)
{
char *a = "abcdefghijklmnopqrstuvwxyz";
int i, j;

if(n < 0) n = 26 - (-n % 26);
for(j = 0; s2[j] = s1[j]; j ++){
for(i = 0; i < 26; i ++){
if(s2[j] == a[i]){
s2[j] = a[(i + n) % 26];
break;
}
}
}
}

int main(void)
{
char s1[64], s2[64];
int n;

printf("文字列を入力---> ");
scanf("%63[^\n]%*[^\n]%*c", s1);
printf("何文字ずらすかを入力---> ");
scanf("%d", &n);
shift(s1, s2, n);
puts(s2);
return 0;
}
    • good
    • 0
この回答へのお礼

教えれいただいて、本当にありがどうございます!

お礼日時:2008/07/18 13:03

#2のかたがいわれているようにyを2文字ずらした場合が、考慮されていません。


以下、実行結果です。
case1
文字列を入力---> az
何文字ずらすかを入力---> 2
2文字ずらした文字列はcbです
これはOKです。
case2
文字列を入力---> ay
何文字ずらすかを入力---> 2
2文字ずらした文字列はcです
これは、NGです。
    • good
    • 0
この回答へのお礼

Thank you very much!

お礼日時:2008/07/18 13:09

・str2が閉じられていない(文字列の末尾にNULL文字がない


・入力の制限だとずらす文字数制限はないがこのプログラムだと問題がでるのでは?
 例えば,zを1文字ずらせばaは考慮されているが,だが27文字ずらせば?
 yを1文字ずらせばzだが,2文字ずらせば?
 
剰余を使った添字を指定を使えばもう少し簡潔にかけませんか?
(25 + 1) % 26 = 0
    • good
    • 0

例題の文字列でテストしてみましたか?


それから、'z'を特別扱いしている理由は何ですか?
    • good
    • 0

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!


おすすめ情報