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

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

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

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

String

Stringは、ゼロ以上の文字から連続してできた文字の集合を扱うデータ型です。基本的にテキストを表すために使われます。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

2回答

1595閲覧

stringクラスによる文字列のAOJの問題です(c++)

_._._ami

総合スコア26

C

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

String

Stringは、ゼロ以上の文字から連続してできた文字の集合を扱うデータ型です。基本的にテキストを表すために使われます。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2020/06/24 05:13

問題

1つのアルファベットが描かれた n 枚のカードの山をシャッフルします。
1回のシャッフルでは、下から h 枚のカードをまとめて取り出し、それを残ったカードの山の上に積み上げます。
カードの山は以下のように1つの文字列で与えられます。

abcdeefab
最初の文字が一番下にあるカード、最後の文字が一番上にあるカードを示しています。

例えば、これを h が 4 でシャッフルすると、最初の4文字 abcd が、残りの文字 eefab の末尾へ連結されるので以下のようになります:

eefababcd
このシャッフルを何回か繰り返します。

カードの山の最初の並び(文字列)と h の列を読み込み、最後の並び(文字列)を出力するプログラムを作成して下さい。

Input
複数のデータセットが入力として与えられます。各データセットは以下の形式で与えられます:

最初の並びを表す文字列
シャッフル回数 m
h1
h2
.
.
hm
最初の並びを表す文字列が "-" のとき入力の終わりとします。

Output
各データセットに対して、最後の並び(文字列)を1行に出力して下さい。

Sample Input
aabc
3
1
2
1
vwxyz
2
3
4

Sample Output
aabc
xyzvw

自分で書いたコードだと例えばaabc/3/1/2/1と入力するとabcaと出力されてしまいます。
繰り返しができていないのだと思いますがどこを改善すれば良いですか?

c++

1#include<iostream> 2#include<cctype> 3#include<string> 4using namespace std; 5 6int main(){ 7 string str,s; 8 int m,h; 9 10 while(1){ 11 cin >> str; 12 if(str == "-") break; 13 14 cin >> m; 15 for(int i=0; i<m; i++){ 16 cin >> h; 17 str = str.erase(0,h-1); 18 s = str.substr(0,h-1); 19 str += s; 20 } 21 22 cout << str << endl; 23 } 24 25 return 0; 26}

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

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

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

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

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

guest

回答2

0

前半と後半をひっくり返すだけでしょう。

C++

1#include <iostream> 2#include <string> 3using namespace std; 4 5int main() 6{ 7 string str; 8 while (cin >> str && str != "-") { 9 int m, h, n = str.size(); 10 cin >> m; 11 while (--m >= 0) { 12 cin >> h; 13 str = str.substr(h, n - h) + str.substr(0, h); 14 } 15 cout << str << endl; 16 } 17}

投稿2020/06/24 06:36

kazuma-s

総合スコア8224

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

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

0

ベストアンサー

C++

1 for (int i = 0; i < m; i++) { 2 cin >> h; 3 str = str.erase(0, h - 1); // ココから 4 s = str.substr(0, h - 1); // 5 str += s; // ココまであやしい。 6 }

std::rotate 使ってみた:

C++

1#include <iostream> 2#include <string> 3#include <algorithm> 4#include <iterator> 5 6int main() { 7 using namespace std; 8 string str, s; 9 int m, h; 10 11 while (1) { 12 cin >> str; 13 if (str == "-") break; 14 15 cin >> m; 16 for (int i = 0; i < m; i++) { 17 cin >> h; 18 rotate(begin(str),prev(end(str),h),end(str)); 19 } 20 21 cout << str << endl; 22 } 23 24 return 0; 25}

投稿2020/06/24 05:56

episteme

総合スコア16612

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

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

fana

2020/06/24 06:17

内容と関係ないですが,毎度本当に文字列操作しなくても最後に一回だけやれば済む話ですよね,これ.
_._._ami

2020/06/24 06:28

ありがとうございます!!!
episteme

2020/06/24 06:44

> 最後に一回だけやれば済む話ですよね ですねー、h積み上げといて最後にまとめてくるくるっと♪
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問