プログラミングのお題スレ Part16

■ このスレッドは過去ログ倉庫に格納されています
2019/11/17(日) 09:00:22.10ID:xqEdXdr6
プログラミングのお題スレです。

【出題と回答例】
1 名前:デフォルトの名無しさん
  お題:お題本文

2 名前:デフォルトの名無しさん
  >>1 使用言語
  回答本文
  結果がある場合はそれも

【ソースコードが長くなったら】 (オンラインでコードを実行できる)
https://ideone.com/
http://codepad.org/
http://compileonline.com/
http://rextester.com/runcode
https://runnable.com/
https://code.hackerearth.com/
http://melpon.org/wandbox
https://paiza.io/

宿題は宿題スレがあるのでそちらへ。

※前スレ
プログラミングのお題スレ Part15
http://mevius.5ch.net/test/read.cgi/tech/1564310397/
97デフォルトの名無しさん
垢版 |
2019/12/04(水) 12:58:50.91ID:61i6ZWvj
print(isletter(c)
98デフォルトの名無しさん
垢版 |
2019/12/04(水) 13:07:17.16ID:61i6ZWvj
>>97
すいません。ブロックされて書き込みができないのでいろいろテスト中。
99デフォルトの名無しさん
垢版 |
2019/12/04(水) 17:21:06.21ID:0j0R5u4a
>>95>>96
打ちまつがえた。
そしてリロードしてなくて書いた直後に上にPerl5の書き込みが出現orz
2019/12/04(水) 22:22:08.38ID:gi4YpuTv
>>67 Perl5

print "@{[1..100]}\n";
2019/12/04(水) 23:37:13.25ID:h1My/is4
お題: 1~100までの数列の和を計算する
2019/12/04(水) 23:58:51.63ID:+9nEsnh/
>>101 Ruby

$><<101.times.sum # => 5050
103デフォルトの名無しさん
垢版 |
2019/12/05(木) 00:15:30.27ID:5juZ/T5v
>>101 julia

print(sum(1:100))
2019/12/05(木) 06:49:18.13ID:5PaJAEA2
return 100*101/2;
2019/12/05(木) 07:16:44.06ID:P/hgT5Y1
>>104
なぜ return 5050; でないのか小一時間ほど問い詰めたい
2019/12/05(木) 07:38:40.50ID:5PaJAEA2
自分で計算したくないから
2019/12/05(木) 07:40:32.01ID:8H7awdOo
最適化されるから一緒
意図がわからない
変数に置き換えて汎用化できない

一時間しゃべってみろよおい
2019/12/05(木) 07:43:45.56ID:5PaJAEA2
>>105に対する>>104の利点

(比較的)変数に置き換えやすい
計算式がわかる
自分で計算しなくて良い
2019/12/05(木) 07:46:36.80ID:5PaJAEA2
>>104 に対する >>105 の利点は何?
2019/12/05(木) 07:47:29.56ID:5PaJAEA2
5文字少ない

だけかな?
2019/12/05(木) 10:43:44.48ID:P/hgT5Y1
>>108
そういうことを言うならせめて
return 100*(100+1)/2;
って書けよ
2019/12/05(木) 13:14:45.51ID:2uRKrxFi
+1
は手計算の手間もないし見ればわかる
非常に利点が少なく
文字入力の手間が相対的に大きくなる
2019/12/05(木) 13:17:19.85ID:2uRKrxFi
どっちでも大差無いけど
2019/12/05(木) 13:21:01.46ID:2uRKrxFi
次は>>105の利点を語ってくれよ
小一時間
115デフォルトの名無しさん
垢版 |
2019/12/05(木) 14:27:21.66ID:esMh+bxM
>>101
Kotlin script

println((1..100).sum())
116デフォルトの名無しさん
垢版 |
2019/12/05(木) 14:31:48.40ID:esMh+bxM
ま、しかし、昔々算数で四角を描いて 100 * (100 + 1) / 2 で出来ると習ったような気がするので馬鹿正直に1から100まで足す必要はないな。
2019/12/05(木) 15:17:30.85ID:2uRKrxFi
工夫出来るところは工夫する
>>105は間違った工夫の例
2019/12/05(木) 18:32:49.00ID:27clmKvC
>>105が小一時間いったい何を問い詰めるつもりだったのか気になる
2019/12/05(木) 18:59:48.69ID:2GEt9xQA
おっすおら小一時間!
これからの議論におらわくわくすっぞ!
120デフォルトの名無しさん
垢版 |
2019/12/05(木) 20:44:21.68ID:lop64poz
>>101
Cの冗談
https://ideone.com/5VLdfV
2019/12/05(木) 21:05:41.72ID:jKYC5XJL
決まり文句のネタレスにえらく執着すんねw
2019/12/05(木) 21:06:33.94ID:5PaJAEA2
1個目の関数で値だけ返すほうが簡単じゃ?
2019/12/05(木) 21:35:53.74ID:P/hgT5Y1
>>118
お前のアホさとか、多分一時間じゃ足りないw
2019/12/05(木) 21:36:32.26ID:P/hgT5Y1
>>117
中途半端な工夫ならしないほうがマシ
2019/12/05(木) 21:55:42.81ID:5PaJAEA2
出て来れないと思ったのに
面の皮厚いね
2019/12/05(木) 22:09:17.41ID:P/hgT5Y1
>>111にレスできないアホがなにか言ってるなw
2019/12/05(木) 22:40:10.86ID:JeZRd2se
小一時間とかサムいフレーズでウケると思ってるからウザがられんだよ
2019/12/05(木) 23:12:12.53ID:2GEt9xQA
俺は別にうざがってないぞ
なに全員がうざがってるみたいなまとめ方するんだよ
2019/12/05(木) 23:23:32.05ID:d0dfL3uy
いいからおまえはどっかで2GEtしてこい
2019/12/05(木) 23:25:08.31ID:8H7awdOo
小一時間問い詰めるとか
具体的に想像すると陰湿極まりないパワハラが思い浮かぶ
2019/12/05(木) 23:35:21.46ID:LiE2fHBS
5ch初心者かよw
2019/12/05(木) 23:39:56.44ID:8H7awdOo
5chのプロかよ
133デフォルトの名無しさん
垢版 |
2019/12/05(木) 23:56:23.39ID:uvnytkqs
こんな煽り合い久々に見たw
2019/12/06(金) 00:22:47.16ID:N/M0C4CM
初心者じゃない奴が全員プロだとでも思ってるのかなぁw
まあとりあえずこれ読んどけ
https://netyougo.com/2ch/2535.html
2019/12/06(金) 01:10:21.76ID:Rsc9FZ2h
用語とか以前に粘着っぷりがやばい
2019/12/06(金) 02:06:00.29ID:RapGeMK4
背筋がサムくなるからもうやめてくれないかな
2019/12/06(金) 03:33:54.64ID:BprTHIND
ものすごい速度で羊を数えてください
1 sheep two sheep three sheep four sheep ...........
2019/12/06(金) 05:57:24.96ID:Ket1H4Yu
>>137
とりあえずお題なの?
曖昧すぎてわからん
2019/12/06(金) 06:42:40.11ID:yuBnjbMi
>>136
>>135
140デフォルトの名無しさん
垢版 |
2019/12/06(金) 14:03:18.53ID:zI729h7a
>>101 julia
f(a,b)=(a+b)*(b-a+1)÷2
f(1,100) #-> 5050
f(50,80) #-> 2015
2019/12/06(金) 22:43:04.72ID:7FicwbM7
>>101 Perl5

use feature current_sub;
print sub {$_[0] and $_[0] + __SUB__->($_[0] - 1)}->(100);
2019/12/06(金) 22:53:13.95ID:7FicwbM7
>>101 Perl5

sub Y_combinator { my $f = shift;
 sub { my $x = shift; $x->($x) }->(
  sub { my $y = shift;
     $f->(sub {$y->($y)(@_)}) }
 )
}
my $series = sub {my $f = shift;
 sub { my $n = shift; $n and $n + $f->($n - 1) }
};
print Y_combinator($series)->(100);
2019/12/06(金) 23:19:56.34ID:jz2bvt/z
お題: 丸カッコと空白の並びで構成される入力文字列がある。丸カッコは入れ子になっていてそれぞれペアになっている。入力文字列は奇数文字数である。
プレーヤー1は、最初に入力文字列の一番左端に居る。プレーヤー2は最初に入力文字列の一番右端に居る。各プレーヤーは一回のアクションで次のいずれかの動作が可能。

(あ) カッコを飛び越えずにひとつ左か右に移動する。ただし、入力文字列の外側には移動できない。
(い) プレーヤーXがカッコAの外側に居て、AとXが隣接しているとき、XがカッコAに対応する別のカッコBの外側の端に移動する。
(う) カッコをひとつまたいでひとつ左か右に移動する。

入力文字列に対してプレーヤー1と2を何度もターン制でアクションをさせてプレーヤーの位置が衝突するまで鬼ごっこをさせよ。
動かすのはランダムでも知能つきでも構わない。アクションごとに位置を表示せよ。
2019/12/06(金) 23:33:56.47ID:jz2bvt/z
知能戦略の例)
鬼はなるべく近くなる方を選ぶ。
子どもは鬼からなるべく遠ざかるように動く。
2019/12/07(土) 00:07:48.78ID:n8phrA6e
動き方がわかりません

1文字右が ( の場合

(あ)1文字右に動く
(い)右の ( に対応する ) の右の文字に動く
(う)2文字右に動く
のいずれかが出来る

ただし、(い) (う) の移動先が文字列の外になる場合は移動出来ない

でいい?
2019/12/07(土) 00:25:15.68ID:FrJsgiML
あ と う は合わせられないか?
2019/12/07(土) 00:25:52.72ID:7zlttp1T
>>101 Perl5

no warnings 'experimental::signatures';
use feature qw(say signatures);

sub f($n) {$n and $n + f($n - 1)};
say f(100);

sub Y($f) { sub {$f->(Y($f))->(@_)} }
say Y(sub($f) { sub($n) { $n and $n + $f->($n - 1) } })->(100);
2019/12/07(土) 00:44:47.39ID:7zlttp1T
>>101 Perl5

no warnings 'experimental::signatures';
use feature qw(say signatures);

sub Y($f) { sub {$f->(Y($f))->(@_)} } # Y combinator w/ recursive
$s = sub ($n) {$n and $n + $s->($n - 1)}; # calc series recursive
say Y(sub ($f) { $s })->(100);
2019/12/07(土) 01:33:07.92ID:7zlttp1T
>>101 Perl5

use List::Util 'sum';
print sum 1..100;
2019/12/07(土) 03:39:00.62ID:GrS1V5od
お題

1以上、20以下の整数がランダムに10個与えられます。

与えられた整数の集合から1つ以上の整数を抜き出し、残った整数の集合からまた1つ以上の整数を抜き出します。

この時2つの抜き出した整数の集合のそれぞれの和が同値であり、かつ最小のものを出力して下さい。



与えられた整数の集合 : 2 3 4 5 6 7 8 9 10 11
期待される出力 : 5
この場合、与えられた整数の集合から
「2,3」「5」の整数を抜き出しています。
2019/12/07(土) 03:47:40.06ID:GrS1V5od
元ネタ
http://itest.5ch.net/test/read.cgi/news4vip/1574130342/18
2019/12/07(土) 04:00:27.84ID:G4M88S/c
・「同値」の意味が謎

・解がない時の処理が謎(e.g. input: 9 10 11 12 13 14 15 16 17 18

・同値の使い方が間違っているのでそもそも「集合」の元が重複しないものとしてよいものか悩ましい
2019/12/07(土) 04:23:11.90ID:GrS1V5od
>>152
同値は単に同じ(等しい)値という意味で使っています。

解が存在しない場合は「ないよー」と出力して下さい。

与えられる整数は重複する可能性があります。
2019/12/07(土) 05:16:02.53ID:HQTo5ewj
ならば結局こういうことでよいのかね.
もとのスレを見ても出題者本人の主張が不明瞭なうえに二転三転していて気持ち悪いが.

与えられた数列を {a_n} に対して,
{a_n} の異なる項からなる任意の部分列の内それぞれの和が等しくなるものを {b_n}, {c_n} として
Σb_n (= Σc_n) が最小となる {b_n}, {c_n} を求めよ.

そして今回は b, c の項数をそれぞれ 2, 1 に限るものとすると.
2019/12/07(土) 05:38:25.75ID:GrS1V5od
もう少し例を載せるべきでした。
すいません。

例えば
>>152
さんの解が存在しないとしているものですが、
9 10 11 12 13 14 15 16 17 18
を与えられた場合の出力は
21となります。(10,11と9,12)


入力が
1 1 1 1 1 1 1 1 1 1
の場合の出力は
1となります。(1と1)
2019/12/07(土) 06:50:35.03ID:HQTo5ewj
>>155
なるほど、概ね理解した
157デフォルトの名無しさん
垢版 |
2019/12/07(土) 09:57:16.56ID:WrheNqRo
>>150
取り敢えずRで力任せ。これでも瞬時に終わるので工夫の必要なし。
https://ideone.com/pCp36v
158デフォルトの名無しさん
垢版 |
2019/12/07(土) 15:33:28.08ID:WrheNqRo
実は>>157は「残った整数の集合から」の条件を忘れていて、元の集合から抜き出すと
勘違いして書いてしまったプログラム。

が、改めて条件を考えてみると、既に抜き出された数と同じものを選んでしまうのは、
「片方の部分集合の要素が2個以上で、もう片方の部分集合の要素が3個以上の場合」(A)
に限られる。例えば、2+9=11と2+3+6=11。この場合、2回選んでしまった2を取り除いた
部分集合は、和9=9と3+6=9が11より小さく、かつ(A)の場合に該当しないので2回選んで
しまった数は存在しない。

だから結局、>>157のプログラムのままで正解が得られることになる。
159デフォルトの名無しさん
垢版 |
2019/12/07(土) 16:28:15.65ID:tj55yZgB
へなへななお題へなへなな回答
2019/12/07(土) 20:45:08.83ID:HU7sPj+p
>>150
この問題から関連して考えてたんだけど
5を
1 1 1 1 1
1 1 1 2
1 1 3
1 2 2
1 4
2 3
5
このように分割する方法は7通り、10だと42通りあった
数が与えられたとき何通りの分け方があるかどうやって計算するのか考えてたけど
そんな簡単な問題ではないようだった

とりあえず数が与えられたら上の例のように全ての分け方を列挙する
というのを問題としてみる
161デフォルトの名無しさん
垢版 |
2019/12/07(土) 22:36:30.68ID:WrheNqRo
>>160
Rでお決まりの再帰呼び出し。
https://ideone.com/LkPChG
2019/12/07(土) 23:22:48.98ID:eT8T+vHJ
分割数でググれば考え方いっぱい出てくるよ
2019/12/08(日) 13:36:47.70ID:jvur7pXC
>>160
C++
https://ideone.com/QVywdv
2019/12/08(日) 13:57:09.43ID:FOSx0Jk/
>>154
最後の文はどこから出てきたの?
2019/12/08(日) 13:58:38.12ID:xElyalHo
>>164
元のスレ
2019/12/08(日) 14:21:04.90ID:FOSx0Jk/
しらんがな
2019/12/08(日) 14:22:15.55ID:FOSx0Jk/
その制限が無い方がアルゴリズムとしておもしろい
制限があるとつまらなすぎる
2019/12/08(日) 17:19:46.37ID:xElyalHo
知らんがなって
なら聞くなアホ
2019/12/08(日) 17:53:26.22ID:FOSx0Jk/
すまん

不満は>>150に言ったつもり
そんな重要な事を省略すんなって
2019/12/08(日) 19:17:22.87ID:DgjgjjxW
別に項数の制限はつけていませんよ
「項数の制限が無い」という事を省略したのに怒っているのならすいません。
ですが制限があるのなら普通に問題文に加えますし、別に書くほどの事では無いかな〜と
2019/12/08(日) 19:37:55.14ID:KCeBLlvA
>>150
https://ideone.com/OJyvxF
C++。総当たりです。スカイレークのi7で12秒くらいかかります。
久しぶりにまじめに総当たりを書いた気がしました。
2019/12/08(日) 19:44:34.35ID:KCeBLlvA
>>150
https://ideone.com/p6FUh4

オマケで、答えが見える版を置いておきます。C++。
2019/12/08(日) 20:22:49.16ID:KCeBLlvA
ちなみにオーダーは大体O(N!)位です。(笑
2019/12/08(日) 20:35:11.71ID:KCeBLlvA
ギャグですけど、並列化は比較的簡単なのでそれで時間短縮はできます。
底の値をシェアードにすると早く終わります。Nになってると思うんだけど。
2019/12/08(日) 20:48:51.01ID:KCeBLlvA
一回を関数に切り出して実行した場合、
一回のイテレーションが大体100回のループに収まるはずなのでザクザクおわります。
多分。
2019/12/08(日) 20:49:16.37ID:KCeBLlvA
一回を関数に切り出して実行した場合、
一回のイテレーションが大体100回のループに収まるはずなのでザクザクおわります。
多分。
2019/12/08(日) 20:59:32.19ID:KCeBLlvA
ぐあ、重複した・・・。
178デフォルトの名無しさん
垢版 |
2019/12/08(日) 21:17:04.79ID:FKbRmDMb
>>150
これは問題の設定がつまらないな。1〜20の中から10個を選んで元の集合を作るから、
結果に1個か2個の和しかほとんど現れず、集合の最初の方をパッと見ただけで
暗算でも分かってしまう。1〜5000の中から10個を選ぶ設定にすると、
結果がなしだったり、3個の和と4個の和だったり、2個の和と6個の和だったり、
変化に富んで面白くなる。https://ideone.com/kmihyT

例えば、リンク先にある

入力: [63, 70, 269, 949, 1337, 2670, 3538, 3764, 4183, 4320]
出力: Σ[3764, 4183] = Σ[63, 70, 269, 1337, 2670, 3538] = 7947

なんてパッと見では思いつかないから、コンピュータに探させる意義がある。
2019/12/08(日) 21:27:36.39ID:KCeBLlvA
>>178
異様に早いなーと思ったら、言語にコンビネーションあるんかいな。
裏山シー。
2019/12/08(日) 22:01:27.05ID:h14g0YSH
サンプルだから人間が簡単に検証できるようにしてるんでしょ
普通それぐらいはわかりそうなもんだけど、>>165みたいに項数だと思う奴とか>>178みたいにイチャモンつける奴とか世の中広いわw
181デフォルトの名無しさん
垢版 |
2019/12/08(日) 22:35:33.47ID:FKbRmDMb
>>180
そんなことは分かっているよ。だから、お題通りの1〜20の場合も>>157でちゃんと回答した。
その上で、もっと面白い場合の追加を提案してみただけ。
2019/12/09(月) 00:06:03.91ID:QbXWD96q
>>150
N!より速い方法ある?
2019/12/09(月) 00:53:44.24ID:rq2SBWAq
>>182
動的計画法?
2019/12/09(月) 01:15:42.30ID:2eMu76Ef
https://ideone.com/52jcdq
全ての和を計算して並べ替えるだけ
多分最も愚直な方法
2019/12/09(月) 01:57:50.57ID:2eMu76Ef
bit演算で面倒なことやってたけどpairっての使えば良かったのか
2019/12/09(月) 02:04:04.39ID:vzskLW//
>>150 https://ideone.com/tKvgv3

By PyPy、 ノーマルpythonでは力業の(N=20)が8秒くらいかな、

力業が 2^N * N

最小値だけなら、N*数列の合計 = N^2 * 数の平均(/2) ででる(みたい?)
(自信ががないDP解)
2019/12/09(月) 02:51:44.21ID:ElWitvQQ
>>180
日本語が読め無い馬鹿発見
2019/12/09(月) 04:54:54.63ID:wE9bCkNR
>>181
わかってたら
> これは問題の設定がつまらないな。
なんていう物言いにはならんだろ

>>187
夜中まで必死だな…
何に必死なのかよくわからんけどw
2019/12/09(月) 05:00:22.33ID:ElWitvQQ
必死なのはお前だろ
お前一人だけ日本語すらまともに読めてない馬鹿だって気づけよ
2019/12/09(月) 06:12:33.29ID:wE9bCkNR
うわっ、アホが無駄に絡んできたよw
2019/12/09(月) 06:42:21.59ID:QCNDYaVq
明け方からどんだけ必死なんだよ
以降、劣等感の塊のID:wE9bCkNRくんが全レスしてくれるってよ!
2019/12/09(月) 06:46:34.43ID:PLlkWb6P
こいつ少し上の方でレスバしてたアホやろ?
さんざん馬鹿にされて悔しい思いしたから早朝にちょろっと顔出してるんやろ
2019/12/09(月) 07:23:51.05ID:RwnUxfkW
単芝ガイジ君、情けなさ過ぎて草
2019/12/09(月) 12:30:02.62ID:G+LM1RHL
>>192
自己紹介乙ww
2019/12/09(月) 15:19:21.58ID:gONUrOAf
https://ideone.com/aYEPpX
C++面白いな
2019/12/09(月) 15:48:30.74ID:gONUrOAf
(sum[i].second & sum[i + 1].second) == 0
この比較はいらないのかな
これが重なってるならより小さい重なってない組合せが必ず存在するか
197デフォルトの名無しさん
垢版 |
2019/12/09(月) 21:07:53.73ID:l5WymCFL
お題:2つの素数(2つは同じでもよい)の積で表される数は半素数と呼ばれる。
1万以下の半素数をすべて表示せよ。
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

ニューススポーツなんでも実況