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

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

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

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

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

Q&A

解決済

3回答

1662閲覧

c++言語。英文(半角スペース区切り)を出現する順に出力せよ。

yoshiki.omj

総合スコア10

C++

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

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

0グッド

0クリップ

投稿2018/03/06 16:13

おねがいします
c++言語について

red green blue blue green blueのような文字列が渡される。

単語、半角スペース、出現回数の順で1行に1単語で出現したすべての単語を、
red 1
green 2
blue 3
のように列に出現する順に出力してください

どなたかこの問題を解いてくれませんか?

#試したこと
-include <iostream>
-include <string>

define MAX_LEN 100

int main() {
int i, len;
char str[] = "This is a test", *words[MAX_LEN], *cp;
const char *delim = " ";

cp = str; for (len = 0; len < MAX_LEN; len++) { if ((words[len] = strtok(cp, delim)) == NULL) break; cp = NULL; } for (i=0; i<len; i++) { puts(words[i]); } return 0;

}

#出力結果
This
is
a
test

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

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

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

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

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

y_waiwai

2018/03/06 16:26

宿題か課題か何かですか?
退会済みユーザー

退会済みユーザー

2018/03/06 22:42

この時期に paiza ラーニングのCランク程度 が出回るのって遊びまわってた専学生か大学生あたりか
guest

回答3

0

ベストアンサー

C++で書くならC++の力をふんだんに使って下さい。

  • 文字列はstd::string等を使って下さい。
  • 標準入出力はstd::cinstd::cout等を使って下さい。
  • 配列や連想配列はstd::vectorstd::map等のコンテナを使って下さい。

そうすれば、大分楽に実装できます。

C++

1#include <iostream> 2#include <string> 3#include <unordered_map> 4#include <list> 5using namespace std; 6int main() 7{ 8 string str; 9 list<string> words; 10 unordered_map<string, int> nums; 11 while ((cin >> str).good()) { 12 if (nums.count(str) == 0) { 13 words.push_back(str); 14 nums[str] = 0; 15 } 16 ++nums[str]; 17 } 18 for (const string& key: words) { 19 cout << key << " " << nums[key] << endl; 20 } 21 return 0; 22}

上のコードは実装例の一つですが、一つの単語がINT_MAXより多くある場合にオーバーフローするバグがあります。

投稿2018/03/06 22:25

raccy

総合スコア21735

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

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

yoshiki.omj

2018/03/07 05:12

ありがとうございます。2週間位ググったりしてもわからなかったのですが、解決できました。vectorやmapの使い方を知ることができました。なぜうまくいったのか調べてみます。
guest

0

C++など不要。そう、シェル芸ならね!

bash

1$ echo "red green blue blue green blue"|xargs -n1|awk 'a[$1]==""{a[$1]=NR}{b[$1]++}END{for(k in a){print a[k],k,b[k]}}'|sort|cut -d' ' -f2,3 2red 1 3green 2 4blue 3

投稿2018/03/06 21:30

編集2018/03/07 01:55
hichon

総合スコア5737

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

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

hichon

2018/03/07 01:56

順番が保存されるように訂正
yoshiki.omj

2018/03/07 05:06

ありがとうございます。シェルを知らなかったので調べてみました。 シェル芸を覚えるメリット • あらゆる処理を一撃で終わらせられる • カッコイイ • 便利 ! • 基本的にパイプで繋ぐので超高速 • マルチプロセスの恩恵をフルに授かれる。 新しい知識としてメモしておきます。
guest

0

puts(words[i]);

を、

printf("%s %d\n",words[i],i+1);

にしましょう

あ、文字列の個数を出すのか。これじゃダメだw


int kosuu[MAX_LEN]; memset(kosuu,0,sizeof(kosuu)); cp=str; for(len=0;len<MAX_LEN;){ char* p=strtok(cp, delim); if(p==NULL) break; int flg=0; for(int j=0;j<len;j++){ if(0==strcmp(words[j],p)){ flg=1; break; } } if(flg){ kosuu[len]++; }else{ words[len++]=p; } }

カウント部のみ。
あとは考えて加筆してくだされw

追記:朝起きると、、ひでー。。

投稿2018/03/06 16:38

編集2018/03/06 22:20
y_waiwai

総合スコア87784

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

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

yoshiki.omj

2018/03/07 05:09

ありがとうございます。ここからfinishまで持っていけない実力がもどかしいです。 flag立てて比較していく考え方までたどり着けなかったので勉強になります!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問