paiza レベルアップ問題集 標準入力その6「STEP: 4 2 行目で与えられる N 個の整数の入力 (large)」をPythonとGASの両方で解いたコードを紹介

この記事を読むことで、Pythonで標準入力inputとsplitなどを用いて、数値の個数と、その全ての数値をループの中で出力することが可能になります。

GASではスプレッドシートで値を取得して、二次元配列にして出力しています。

このコーナーでは、プログラミング学習コンテンツpaizaラーニングレベルアップ問題集を、PythonとGAS(Google Apps Script)の両方で同じ問題を解いたコードを公開している学習ログです。

Python・GASのどちらの言語のコードも可能な限り詳細に解説致します。
GASはスプレッドシートのエディタを使ってコードを書いております。

Pythonではpaizaに入会しなくても問題集を解きたい方向けにpaiza.ioを用いております。paiza.ioの使い方はこちらから。

(入会するか否かは問題集を解いて見てからの読者様のご判断にお任せ致します。
どちらの選択をされても記事を読めるようになっておりますので、ご安心なさって下さい。)


2 行目で与えられる N 個の整数の入力 (large) (paizaランク D 相当)

問題:
1 行目で整数 N が与えられます。
2 行目で、N 個の整数 a_1, … , a_N が半角スペース区切りで与えられます。
a_1, … , a_N を改行区切りで出力してください。

ではまず、Pythonで解いてみます。

手順として、

1: 1行目を標準入力で整数型Nとして取得する

2: 2行目を標準入力inputやsplitといった関数などを使って半角スペース区切りの整数をリストarrayに取得する

3: リストarrayをループで出力する

・基本的なループ
・リスト出力に適したループ
・上記の内包表記  

の3ステップで行います。

今回は入出力例1を用います。

入力例1
5
8 1 3 10 100

出力例1
8
1
3
10
100

まず、準備として、paiza.ioにこのように入力します。
(入力例1 をコピペしたのみ)

Green execute button labeled 実行 (Ctrl-Enter) at the top, with a numeric input area below showing a tab labeled 入力 and numbers: 5 and 8 1 3 10 100.

まずは、1行目の数値の個数5を標準入力で取得して、変数Nに代入して、正しく取得できたことをprint関数で確認します。

#1行目を標準入力で数値として取得して個数Nに代入する
N=int(input())

#数値の個数Nが取得できたことを確認する
print(N)

実行結果です。

Green rounded Run button labeled 実行 (Ctrl-Enter) with an arrow icon; a tab strip shows 出力, 入力, コメント with a blue 0 badge, and the content area displays 5.

無事に数値の個数N=5個が取得出来ました。

5個の数値は下記のコードで取得出来ますが、1行に複数の関数などが使われているので、今回の例に即して簡潔にお伝えします。

input … 標準入力で文字や数値を取得する

split … 指定の区切り文字で分割して取得する

int … 上記で取得する対象が整数である


rstrip … 右側にある不要な空白を取り除く


map … まとめて適用


list … リスト(配列)変換

上記を用いてコードを掲載致します。
一気に色々出て来てしまいましたので、まずは、標準入力で取得した数値がリスト(配列)形式でarrayに取得出来たことをprint文で出力して確認します。

N=int(input())
print(N)

#2行目からN個分の数値をリストarrayに取得
array=list(map(int,input().rstrip().split(' ')))

#リストarrayにN個の数値が格納されたことを確認する
print(array)

出力結果です。

Green execute button labeled 実行 (Ctrl-Enter) at top; below, UI tabs and a pink outlined input area containing the array [8, 1, 3, 10, 100].

まずは、リストとして無事に出力が出来ました。


では、リストarrayをループを用いて解答の出力例に沿って縦に出力します。
最も基礎的なループでは、この様なコードになります。

ループの中では、iの値が0,1,2,3,4の5つ、1つ分増えて行きます。
リストの添字は0から始まり、N=5ですのでarray[i]は、

array[0]=8
array[1]=1
array[2]=3
array[3]=10
array[4]=100

の5つの値が取得出来ます。

for i in range(N):

N=int(input())

#確認用の出力の為、後で消す
print(N)

array=list(map(int,input().rstrip().split(' ')))

#確認用の出力の為、後で消す
print(array)

#リストarrayをループで出力する
for i in range(N):
    print(array[i])
    

出力結果です。

UI screenshot with a green Run button labeled 実行 (Ctrl-Enter), tabs for 出力, 入力, コメント, and a red-outlined vertical list showing 8, 1, 3, 10, 100 on the left.

ループを用いて、解答の形に沿った縦型に出力出来ました。
一度コードの整理で、確認用に使ったprint文をコメントアウトします。

N=int(input())
#print(N)

array=list(map(int,input().rstrip().split(' ')))
#print(array)

#リストarrayをループで出力する
for i in range(N):
    print(array[i])


この状態で実行すると、

Green rounded Run button labeled 実行 (Ctrl-Enter) at top; beneath is a tab strip with 出力, 入力, コメント and a blue 0 badge; left-aligned column shows numbers 8, 1, 3, 10, 100 on a light background.

この様にスッキリしました。


次に、リストを使った、更に便利なループの表記方法について掲載致します。

for リストの要素の文字 in リスト名:

今回の例ですと、

for num in array:

等になります。

リストの要素の所は自分や他の方が見て分かりやすい「num」などにすると、「整数を取り出すんだな」と伝わりやすいです。

コメントアウトした部分を削除したコードを掲載致します。

N=int(input())
array=list(map(int,input().rstrip().split(' ')))

#arrayをリストに適したループで出力する
for num in array:
    print(num)

この書き方でも同様の出力結果になりました。


更にコード短くするには、ループをたった1行で表記する内包表記を用います。

[出力結果のprint文 for リストの要素の文字 in リスト名]

今回の例ですと、

[print(num) for num in array]

と表記致します。

N=int(input())
array=list(map(int,input().rstrip().split(' ')))

#リストarrayを内包表記で出力する
[print(num) for num in array]

Pythonは以上です。
次は、GASで解いて行きます。


今度は、同じ問題をGASで解いてみます。
まず、スプレッドシートにこの様に配置しました。

緑色のセルに数字の個数Nを、灰色の所のN個の数を取得し、それを黄色いセルに出力します。その際、この黄色いセルの所には、二次元配列として取得した整数が格納された配列を出力します。

※スプレッドシートに表示する場合は、二次元配列としての配列に追加をして作成します※

手順はこのようになります。

1:SpreadSheetAppから階層を辿って現在のシートにアクセスする
2:緑色と灰色のセルを二次元配列numとして取得
3:取得したnumをログ出力
4:num[0][0]を数字の個数Nに格納
5:num[1][0]にsplitメソッドを使って、配列arrayに格納
6:取得した配列arrayをログ出力する
7:配列arrayを二次元配列array2にループで格納
8:スプレッドシート格納前に二次元配列array2をログ出力する
9:スプレッドシートの黄色い所に格納する

手順1: SpreadSheetAppから階層を辿って現在のシートにアクセスする

const ss = SpreadsheetApp.getActiveSheet();

ここで定数ssにSpreadsheetAppから階層を辿ってアクティブシートにアクセスしています。

手順2:緑色と灰色のセルを二次元配列numとして取得

num=ss.getRange(1,1,2).getValues();

手順3:取得したnumをログ出力

console.log(num);

手順4:num[0][0]を数字の個数Nに格納

const N=num[0][0];

手順5:num[1][0]にsplitメソッドを使って、配列arrayに格納

const array=num[1][0].split(‘ ‘);

手順6:取得した配列arrayをログ出力する

console.log(array);

手順7:配列arrayを二次元配列array2にループで格納

//配列arrayを二次元配列array2にループで格納
  let array2=[];
  for(let i=0;i<N;i++){
    array2.push([array[i]]);
  }

手順8:スプレッドシート格納前に二次元配列array2をログ出力する

console.log(array2);

手順9:スプレッドシートの黄色い所に格納する

ss.getRange(1,3,N).setValues(array2);

実行後のスプレッドシートです。

GASでの全コードはこちらになります。

function standardInput27(){
  
  //SpreadSheetAppから階層を辿って現在のシートにアクセスする
  const ss=SpreadsheetApp.getActiveSheet();

  //緑色と灰色のセルを二次元配列numとして取得
  num=ss.getRange(1,1,2).getValues();

  //取得したnumをログ出力
  console.log(num);

  //num[0][0]を数字の個数Nに格納
  const N=num[0][0];

  //num[1][0]にsplitメソッドを使って、配列arrayに格納
  const array=num[1][0].split(' ');

  //取得した配列arrayをログ出力する
  console.log(array);

  //配列arrayを二次元配列array2にループで格納
  let array2=[];
  for(let i=0;i<N;i++){
    array2.push([array[i]]);
  }

  //スプレッドシート格納前に二次元配列array2をログ出力する
  console.log(array2);

  //スプレッドシートの黄色い所に格納する
  ss.getRange(1,3,N).setValues(array2);
  
}

GASは以上です。

※ この記事の作成に参考になったサイトです ※
ありがとうございます。

Python「rstrip() メソッド」で文字列の右端を整えよう!
Python mapの使い方

宜しかったらコピペしてアレンジして見て下さい。
お疲れ様でした、ブレイクタイムフォトはこちらになります。

よみうりランド、ジュエルミネーション

←前の問題へ          次の問題へ→

ご精読有難うございました。

■ GASの入門書の紹介です ■

詳解! Google Apps Script完全入門 [第3版]
単行本
Kindle版(電子書籍)

■ 関連記事 ■

paizaレベルアップ問題集「標準入力6」へ戻る
paizaレベルアップ問題集_PythonとGASのコード紹介トップページへ

写真クリエイターとしての活動
自己紹介

投稿者アバター
nekosiestr
いつもブログをご覧頂きまして、誠に有難うございます。 Excelやデータベース、プログラミングを学習する傍ら、趣味で写真を撮影してPhotoshopで編集しております。

投稿者: nekosiestr

いつもブログをご覧頂きまして、誠に有難うございます。