プログラミングのお題 ..
[2ch|▼Menu]
314:デフォルトの名無しさん
19/12/14 03:55:22 DhSlagHw.net
お題: 目覚まし時計の現在時刻とアラーム時刻が入力されるので、待機時間を出力しなさい

例:
現在時刻 = 10:00
アラーム時刻 = 16:00
待機時間 = 06:00

現在時刻 = 22:00
アラーム時刻 = 04:00
待機時間 = 06:00

315:デフォルトの名無しさん
19/12/14 09:12:53.23 ruM/1CH5.net
>>309
これだな
URLリンク(paiza.io)
~/bin/sleep.pl


316:10:00 2909 00:48:29 のように使ってる



317:デフォルトの名無しさん
19/12/14 09:59:37.97 Lp9CT80F.net
>>304
進振り何点だった? 連投アスペ君

318:デフォルトの名無しさん
19/12/14 22:12:52.90 8CJijD11.net
>>309
この手の処理はPowerShellが得意だな。
function WaitingTime($now, $alarm)
{
  $wait = [DateTime]$alarm - [DateTime]$now
  if ($wait -lt 0) {$wait += [TimeSpan]"12:00" + [TimeSpan]"12:00"}
  "現在時刻 = $now"
  "アラーム時刻 = $alarm"
  "待機時刻 = $wait"
  ""
}
WaitingTime 10:00 16:00
WaitingTime 22:00 4:00
WaitingTime 12:34:56 1:23:45
--- 実行結果 ---
現在時刻 = 10:00
アラーム時刻 = 16:00
待機時刻 = 06:00:00
現在時刻 = 22:00
アラーム時刻 = 4:00
待機時刻 = 06:00:00
現在時刻 = 12:34:56
アラーム時刻 = 1:23:45
待機時刻 = 12:48:49

319:デフォルトの名無しさん
19/12/15 00:16:05 K3IRPfAN.net
>>312
キャスト出来るんだな
楽そう

320:デフォルトの名無しさん
19/12/15 06:09:40 K3IRPfAN.net
お題: あなたは研究所で助手をしています
ある日、博士からこんな手紙が届きました

 助手よ。この数値の名前を教えて欲しい
 16776960

あなたは博士に返事を書こうと思います
その返事の内容をお答えください

321:デフォルトの名無しさん
19/12/15 07:44:00 VJoyKt1C.net
>>314 直感
Yellow

322:デフォルトの名無しさん
19/12/15 10:09:42 /SOvb5b/.net
黄色だな

323:デフォルトの名無しさん
19/12/15 11:56:51.84 wptEtnNg.net
お題
与えられた自然数の0を全て右端に寄せる

2019 -> 2190
102030 -> 123000
123 -> 123

324:デフォルトの名無しさん
19/12/15 12:02:23.68 fpSJINfx.net
>>309
Ruby で、
require 'active_support/time'
def calculate_time_span( now, alarm )
current = Time.now
now_time = Time.parse( now, current ) #=> 2019-12-15 22:00:00 +0900
alarm_time = Time.parse( alarm, current ) #=> 2019-12-15 04:00:00 +0900
diff_time = alarm_time - now_time
# アラームが翌日の場合
diff_time = alarm_time.tomorrow - now_time if diff_time < 0
Time.at( diff_time ).utc.strftime( '%H:%M' )
end
inputs = %w(10:00 16:00 22:00 04:00) # (現在時刻, アラーム時刻)の組
inputs.each_slice( 2 ) do |now, alarm| # 2個ずつ処理する
puts calculate_time_span( now, alarm )
end

325:デフォルトの名無しさん
19/12/15 13:16:18.52 VJoyKt1C.net
>>309 Ruby
def waitTime( n, a )
Time.at( (a - n) % 86400 ).utc
end

326:デフォルトの名無しさん
19/12/15 15:13:57.70 KhVK4v3Y.net
>>309
URLリンク(ideone.com)
C++。あってるかな?

327:デフォルトの名無しさん
19/12/15 15:21:49.83 yZPHpztp.net
>>317 Common Lisp
URLリンク(ideone.com)

328:デフォルトの名無しさん
19/12/15 15:38:04.40 KhVK4v3Y.net
>>317
URLリンク(ideone.com)
C++。できてるかな?

329:デフォルトの名無しさん
19/12/15 16:45:12.24 K3IRPfAN.net
>>315-316
正解

330:デフォルトの名無しさん
19/12/15 20:15:30.36 IFqyyeL5.net
>>317
これもPowerShellで簡単。
function f($n)
{
  $m = -join([char[]]"$n" |? {$_ -ne "0"})
  ($m += "0" * ("$n".length - $m.length))
}
f 2019; f 102030; f 123

331:デフォルトの名無しさん
19/12/15 22:45:37.77 myBFLrpG.net
お題:ハノイの塔の最少手数は一種類しかないのか?
  (Part 13, 055)
結果:n枚の円盤すべてを移動させるには最低 2^n −1 回の手数がかかる。

332:デフォルトの名無しさん
19/12/15 22:58:29.31 myBFLrpG.net
4ピンのハノイの塔(河内塔)
n枚の円盤は最初ピン0にある。n枚すべてをピン3に移動させる。
条件:
 小円盤の上に大円盤を載せられない。
 ピン1とピン2には最大1枚しか置けない。

333:デフォルトの名無しさん
19/12/15 23:12:15.95 myBFLrpG.net
・n=2 のとき
12, -, -, -
2, 1, -, -
-, 1, -, 2
-, -, -, 12  (3手)
・n=3 のとき
123, -, -, -
23, 1, -, -
3, 1, 2, -
-, 1, 2, 3
-, 1, -, 23
-, -, -, 123  (5手)
・n=4 のとき
1234, -, -, -
234, 1, -, -
34, 1, 2, -
4, 1, 2, 3
4, 1, -, 23
-, 1, 4, 23
2, 1, 4, 3
12, -, 4, 3
12, 3, 4, -
12, 3, -, 4
12, -, -, 34
2, 1, -, 34
-, 1, -, 234
-, -, -, 1234  (13手)

334:デフォルトの名無しさん
19/12/15 23:25:59.52 myBFLrpG.net
・n=5 のとき
12345, -, -, -
2345, 1, -, -
345, 1, 2, -
45, 1, 2, 3
45, 1, -, 23
45, -, -, 123
5, 4, -, 123
-, 4, 5, 123
4, -, 5, 123
4, 1, 5, 23
24, 1, 5, 3
124, -, 5, 3
124, 3, 5, -
124, 3, -, 5
24, 3, 1, 5
4, 3, 1, 25
4, 3, -, 125
-, 3, 4, 125
3, -, 4, 125
3, 1, 4, 25
23, 1, 4, 5
23, 1, -, 45
3, 1, 2, 45
-, 1, 2, 345
-, 1, -, 2345
-, -, -, 12345  (25手)

335:デフォルトの名無しさん
19/12/16 08:07:19.12 YuYKZXFs.net
お題:
ここに単語を登録したリストがある
リストには以下の種類の言葉が存在する
単語:(例)くさり
単語解説:(例)環状の部品を繋げて線状にしたもの
リストには上記ペアを1単位として、ずらずら並んでいる
(数十個くらい)
リストの中の似たような単語を探し、
以下のサンプルのようにボケ、ツッコミを繰り返すプログラムを作れ
似たような単語が見つからない場合には
最後に「こうじ:お前とはもうやってられませんわ」とprintし、
プログラムを終了せよ
動作サンプル:
こうじ:「くさび」を見ると興奮するよね
てつお:ああ、環状の部品を繋げて線状にしたものね
こうじ:それは「くさり」
てつお:ああ、マルスダレガイ科に属する二枚貝ね
こうじ:それは「あさり」
てつお:ああ、慰安婦の嘘を書いた新聞ね
こうじ:それは「あさひ」
こうじ:お前とはもうやってられませんわ

336:デフォルトの名無しさん
19/12/16 09:38:23.88 UpTR80vx.net
>>326
・n≧6のとき
ピン1とピン2には各1個しか置けないから 1〜(n-1) を置くことはできない。
∴ n を ピン0 から ピン3 に直送することはできない。
∴ ピン0 → ピン1 → ピン3 と送ろう。
まず 12345 をピン2、ピン3に退避する。(n=6の場合)
 123456, -, -, -
 6, -, m, 12345-m  (1≦m≦5)
 6, -, -, 12345    は m=1 と見なす。
 -, 6, m, 12345-m
次にピン3を空けるため、ピン0とピン2に移すことになる。
しかしピン0には3枚しか移動できず、ピン3に n-5枚残ってしまう。
∴ n≧6 では不可能。

337:デフォルトの名無しさん
19/12/16 10:03:17.28 UpTR80vx.net
条件を変えたらどうなるか?
条件(1,1)
 ピン1、ピン2には最大で1枚しか置けない。   >>326
条件(1,2)
 ピン1には最大で1枚、ピン2には最大で2枚しか置けない。
条件(2,2)
 ピン1、ピン2には最大で2枚しか置けない。

338:デフォルトの名無しさん
19/12/16 12:12:45.33 ZZ8St2Js.net
>>331
pin1,pin2に置ける枚数(の合計)に上限があれば
移動可能枚数に上限がつく

339:デフォルトの名無しさん
19/12/16 14:51:32.32 b9yK9thh.net
>>314
common lisp
(format t "~R" 16776960)
sixteen million, seven hundred and seventy-six thousand, nine hundred and sixty

340:デフォルトの名無しさん
19/12/16 15:02:43.75 b9yK9thh.net
>>317
perl5
cat digits
2019
102030
123
cat digits | perl -lane '$zero = 0; while (s/0//) {++$zero}; print $_ . "0" x $zero;'
2190
123000
123

341:デフォルトの名無しさん
19/12/16 17:56:02.69 rcGH9Ke6.net
>>317 Ruby
def f(n)
n.to_s.chars.partition{|x| x !="0"}.join .to_i
end

342:
19/12/16 20:29:58.89 NZyGx79l.net
>>326
これ昔やったことがありますが、すっかり忘れてしまったのは残念ですね…

343:デフォルトの名無しさん
19/12/16 22:11:10.55 Ppfui4Eb.net
>>317 PowerShell
function f($n) {($n -replace "0", "") + ($n -replace "[^0]", "")}

344:デフォルトの名無しさん
19/12/17 01:24:02.19 XiWpNBJ4.net
>>317 Common Lisp
URLリンク(ideone.com)

345:デフォルトの名無しさん
19/12/17 04:04:38.21 XiWpNBJ4.net
>>317 Common Lisp
>>338は間違いでした
修正版: URLリンク(ideone.com)

346:デフォルトの名無しさん
19/12/17 13:17:36.43 EDJKyz+u.net
>>317 julia
function f(n)
  r = ""
  for c = reverse(string(n))
    if c == '0'
  r = r * c
    else
      r = c * r
    end
  end
  parse(Int, r)
end

347:デフォルトの名無しさん
19/12/17 17:33:51.45 /DSBUbt2.net
お題
任意の文字列からaが連続する最も長い長さを出力してください
入力:acgtaattgaaagggtctt
期待値:3

348:デフォルトの名無しさん
19/12/17 18:10:05.60 Etag1t/i.net
>>341 Common Lisp
URLリンク(ideone.com)

349:デフォルトの名無しさん
19/12/17 18:50:00.42 Etag1t/i.net
>>342
うん? またバグってた
>>341 Common Lisp
URLリンク(ideone.com)

350:デフォルトの名無しさん
19/12/17 19:34:15.94 JvBVW/sd.net
>>317 C++
数値のままやってみた
URLリンク(ideone.com)

351:デフォルトの名無しさん
19/12/17 20:02:20.13 bKU/e1zO.net
>>341 Ruby
p 'acgtaattgaaagggtctt'.gsub(/[^a]+/,' ').split.uniq.sort_by{|s| s.size}.last.size

352:デフォルトの名無しさん
19/12/17 21:06:34.08 eGUcswGM.net
お題
1〜1,000 の整数の内、3 か5 の倍数だけを選んで、その合計を求めよ

353:デフォルトの名無しさん
19/12/17 21:42:29.19 p+XnOFki.net
>>346
Rで2通りの求め方
d <- c(3, 5, -3 * 5)
q <- 1000 %/% d
cat(sum(d * q * (q + 1) / 2), "\n")
cat(sum(which(1:1000 %% 3 == 0 | 1:1000 %% 5 == 0)), "\n")
--- 実行結果 ---
234168
234168

354:デフォルトの名無しさん
19/12/17 21:42:34.96 Q1C16S4i.net
>>341 Ruby
p 'acgtaattgaaagggtctt'.scan(/a+/).max.size # => 3

>>346 Ruby
p 0.step(1000,3).sum + 0.step(1000, 5).sum - 0.step(1000, 15).sum # => 234168

355:デフォルトの名無しさん
19/12/17 21:45:36.79 Q1C16S4i.net
>>348
typo
/a+/ => /a*/

356:
19/12/17 21:47:21.34 780pCLgH.net
お題:ファイル名の一部に空白文字が使える OS(出題者想定は Windows7) の元で、正常に argc, argv を切り出せるスタートアップ支援ルーチンを作ってください
"" で囲まれている文字列は、それが一つのファイル名またはディレクトリ名として扱うこととし、"" で囲まれていない空白は引数の区切りとします
int main() {
rearrange(...);
...
と main の頭に置いて、xargc, xargv を代わりに使う、見たいな感じでお願いします
例によって私が痛切に欲しいと思っているものです…

357:デフォルトの名無しさん
19/12/17 23:55:17.00 jG+XSsUd.net
>>341は簡単すぎるので、
任意の文字列から連続してる文字が最も長い文字とその文字数を求めよ
最も長い文字が複数ある場合は全て出力すること
入力:acgtaattgaaagggtctt
期待値: ("a", 3), ("g",3)

358:デフォルトの名無しさん
19/12/18 00:00:22.88 mWocJHci.net
期待値
の意味って学校で習わなかった?

359:デフォルトの名無しさん
19/12/18 00:01:42.93 i+6d3gEf.net
>>350
依頼禁止

360:デフォルトの名無しさん
19/12/18 00:09:07.64 i+6d3gEf.net
>>346 C
int s(int n){ return (1000/n)*(1000/n+1)/2*n; }
int main(){ return s(3)+s(5)-s(15); }

361:デフォルトの名無しさん
19/12/18 00:12:20.91 i+6d3gEf.net
int main(){ return 234168; }
で良い気がしてきた

362:デフォルトの名無しさん
19/12/18 00:13:22.10 LTf


363:Q+mrC.net



364:デフォルトの名無しさん
19/12/18 00:28:03.60 i+6d3gEf.net
どうせコンパイルしたら>>355になる

365:デフォルトの名無しさん
19/12/18 01:55:09 JeMlTDQr.net
>>351 Common Lisp
URLリンク(ideone.com)

366:デフォルトの名無しさん
19/12/18 06:09:15.93 6RKB+CQ3.net
>>351 Ruby
p 'acgtaattgaaagggtctt'.scan(/((.)\2*)/).group_by{|s, _| s.size}.max&.last&.map{|s, c| [c, s.size]}
# => [["a", 3], ["g", 3]]

367:デフォルトの名無しさん
19/12/18 10:45:51.93 AmwvkO78.net
acgtが出てくんだからながさ1億の文字列なんじゃね

368:蟻人間
19/12/18 11:33:42.87 Zo1XP656.net
>>350
__getmainargs

369:デフォルトの名無しさん
19/12/18 12:47:12.26 Xcao9p4E.net
acgtが出てくんだからDNA配列だろな。
 a=adenine, c=cytosine, g=guanine, t=thymine
ながさ30億の塩基対なんぢゃね?(ヒトの場合)

370:デフォルトの名無しさん
19/12/18 13:00:45.28 Xcao9p4E.net
>>331
・n=7 のとき
 条件(1,2) または 条件(2,2) とする。
 1234567, -, -, -
  (>328)
 67, -, -, 12345
 7, 6, -, 12345
 -, 6, 7, 12345
 6, -, 7, 12345
  (>327)
 12346, -, 7, 5
 12346, 5, 7, -
 12346, 5, -, 7
 12346, -, 5, 7
   (>327)
 6, -, 5, 12347
 6, 5, -, 12347
 -, 5, 6, 12347
 5, -, 6, 12347
   (>327)
 12345, -, 6, 7
 12345, -, -, 67
   (>328)
 -, -, -, 1234567
にて可能。

371:デフォルトの名無しさん
19/12/18 13:04:26.11 iEIErwam.net
(1,2)で8
(2,2)だと12
までは出来たぞ

372:デフォルトの名無しさん
19/12/18 13:06:11.00 iEIErwam.net
(1,3)で11
紙と鉛筆で考えただけなんで
もっと出来るかも

373:デフォルトの名無しさん
19/12/18 13:29:12.80 iEIErwam.net
(n,1)=3n+2
(2,2)以上だと
(m, n)=4(n+m-1)
まではいける

374:デフォルトの名無しさん
19/12/18 14:02:18.59 1FTJXM5f.net
>>317
Kotlin
URLリンク(paiza.io)
実は数字かどうかではなく '0' かどうかで見てるだけ。

375:デフォルトの名無しさん
19/12/18 14:58:11.70 Xcao9p4E.net
>>331
・n=8のとき
 条件(1,2) または 条件(2,2) とする。
 12345678, -, -, -    (>328)
 678, -, -, 12345
 78, -, 6, 12345      (>328)
 1234578, -, 6, -
 1234578, -, -, 6     (>328)
 78, -, -, 123456
 8, 7, -, 123456
 -, 7, 8, 123456
 7, -, 8, 123456      (>328)
 123457, -, 8, 6
 123457, 6, 8, -
 123457, 6, -, 8
 123457, -, 6, 8      (>328)
 7, -, 6, 123458
 7, 6, -, 123458
 -, 6, 7, 123458
 6, -, 7, 123458      (>328)
 123456, -, 7, 8
 123456, -, -, 78     (>328)
 6, -, -, 1234578
 -, -, 6, 1234578     (>328)
 12345, -, 6, 78
 12345, -, -, 678     (>328)
 -, -, -, 12345678
にて可能。
・n=9 は 条件(1,2) では無理か・・・・

376:デフォルトの名無しさん
19/12/18 16:04:48.01 iEIErwam.net
(0,0)=1
(n,m)=(n+2)(m+2)-4
ですかね

377:デフォルトの名無しさん
19/12/18 21:05:50.74 WdZQqUwr.net
>>359
Rでrle関数を使って楽々
MaxRepChar <- function(s) {
 if (!nchar(s)) return(invisible())
 r <- rle(unlist(strsplit(s, "")))
 b <- r$lengths == max(r$lengths)
 cat(sprintf('("%s", %d)', r$values[b], r$lengths[b]), sep = ", "); cat("\n")
}
MaxRepChar("acgtaattgaaagggtctt")
MaxRepChar("スレリンク(tech板)")
-- 実行結果 --
("a", 3), ("g", 3)
("t", 2), ("/", 2), ("8", 2), ("2", 2)

378:デフォルトの名無しさん
19/12/18 21:06:21.05 H5ShkPcr.net
f(m, n) : 動かせる最大枚数
m≧n≧1の時
x=f(m-1,n)
A:1,2,3,...,x
B:x+1,...,x+n
C:x+n+1
D:x+n+2
ABCD, -, -, -
CD, -, -, AB
C, D, -, AB
AC, D, -, B
AC, -, -, BD
C, -, - ABD
-, C, -, ABD
A, C, -, BD
A, -, -, BCD
-, -, - ABCD
よって
f(m, n)≧f(m-1,n)+n+2
f(1,0)=2
f(m,n)=f(n,m)
と数学的帰納法により
f(m,n)≧(m+2)(n+2)-4

379:
19/12/18 22:57:24.30 tbeJyQYA.net
>>371
理論はどうでもいいから動く


380:コードを出して欲しいです、このスレ的には



381:デフォルトの名無しさん
19/12/18 23:01:39.59 i+6d3gEf.net
ここまで出来ればあとは簡単
他の人に任せた

382:デフォルトの名無しさん
19/12/19 00:58:04.71 1AoIgbUn.net
>>317 文言 wenyan-lang
URLリンク(wenyan-lang.lingdong.works)
吾有一術。名之曰「零右寄」。欲行是術。必先得一數。曰「数」。乃行是術曰。
吾有三數。曰零。曰零。曰一。名之曰「甲」曰「乙」曰「丙」。
恆為是。若「数」等於零者乃止也。除「数」以十。所餘幾何。昔之「甲」者。今其是矣。
若「甲」等於零者。乘「乙」以十。昔之「乙」者。今其是矣。若非。乘「甲」以「丙」。
加其以「乙」。昔之「乙」者。今其是矣。也。除「数」以十。昔之「数」者。今其是矣。
除其以一。所餘幾何。減「数」以其。昔之「数」者。今其是矣。
乘「丙」以十。昔之「丙」者。今其是矣。云云。乃得「乙」。是謂「零右寄」之術也。
吾有一列。名之曰「丁」。充「丁」以二千零一十九。以一十萬二千零三十。以一百二十三。
凡「丁」中之「戊」。施「零右寄」於「戊」。名之曰「己」吾有三數。曰「戊」。曰「「、」」。曰「己」。書之。云云。
OUTPUT ---------------------
二千零一十九、二千一百九十
一十萬二千零三十、一十二萬三千
一百二十三、一百二十三

なんかGIGAZINEで紹介されていたので

383:デフォルトの名無しさん
19/12/19 03:38:08.86 i+MhtJYW.net
>>363
・n=7 のとき
 条件(1,2) または 条件(2,2)
 {1234}=A と略記する。
 A567, -, -, -   (>327)
 567, -, -, A
 67, 5, -, A
 7, 5, 6, A
 57, -, 6, A    (>327)
 A57, -, 6, -
 A57, -, -, 6   (>327)
 57, -, -, A6
 7, 5, -, A6
 -, 5, 7, A6
 5, -, 7, A6    (>327)
 A5, -, 7, 6
 A5, 6, 7, -
 A5, 6, -, 7
 A5, -, -, 67    (>327)
 5, -, -, A67
 -, -, 5, A67    (>327)
 A, -, 5, 67
 A, -, -, 567    (>327)
 -, -, -, A567
にて可能。

384:デフォルトの名無しさん
19/12/19 03:43:24.67 i+MhtJYW.net
>>368
・n=8のとき
 条件(1,2) または 条件(2,2)
 {12345} = A と略記する。
 A678, -, -, -       (>328)
 678, -, -, A
 78, 6, -, A
 8, 6, 7, A
 68, -, 7, A       (>328)
 A68, -, 7, -
 A68, -, -, 7       (>328)
 68, -, -, A7
 8, 6, -, A7
 -, 6, 8, A7
 6, -, 8, A7       (>328)
 A6, -, 8, 7
 A6, 7, 8, -
 A6, 7, -, 8
 A6, -, -, 78       (>328)
 6, -, -, A78
 -, -, 6, A78     (>328)
 A, -, 6, 78
 A, -, -, 678       (>328)
 -, -, -, A678
にて可能。

385:デフォルトの名無しさん
19/12/19 04:34:36.23 i+MhtJYW.net
・n=12 のとき
 条件(2,2)
{12345678} = A, {9,10} = B, 11=C, 12=D と略記する。
 ABCD, -, -, -   (>376)
 BCD, -, -, A
 CD, -, B, A
 D, C, B, A
 BD, C, -, A    (>376)
 ABD, C, -, -
 ABD, -, -, C   (>376)
 BD, -, -, AC
 D, -, B, AC
 -, D, B, AC
 B, D, -, AC    (>376)
 AB, D, -, C
 AB, D, C, -
 AB, -, C, D
 AB, -, -, CD   (>376)
 B, -, -, ACD
 O, 9, -, ACD   (>376)
 AO, 9, -, CD
 AO, -, -, 9CD   (>376)
 O, -, -, A9CD
 -, O, -, A9CD   (>376)
 A, O, -, 9CD
 A, O, 9, CD
 A, -, 9, OCD
 A, -,-, BCD    (>376)
 -, -, -, ABCD
にて可能。

386:デフォルトの名無しさん
19/12/19 07:01:53.01 NLbJ7Izu.net
>>317 J
f =: 3 : 0
a =. ": y
b =. a -. '0'
". b , a -. b
)

387:346
19/12/19 11:40:09.74 dMnFAlGo.net
>>346
Ruby で、234,168
# 蓄積変数の初期値は、0
puts ( 1..1_000 ).inject( 0 ) { |sum, num|
num % 3 == 0 || num % 5 == 0 ? sum + num : sum
}

388:デフォルトの名無しさん
19/12/19 13:03:26.44 LRZ6v8WB.net
>>375-377
>>371で理論は出来たんだから
次は
プログラムにするか
等号の証明をするか
最短手順を調べるか
本数を増やすか
ではないでしょうか?
私は>>371で満足
出題者ありがとう

389:デフォルトの名無しさん
19/12/19 14:49:39.96 i+MhtJYW.net
>>380
う〜む、等号の証明でござる。

390:デフォルトの名無しさん
19/12/19 16:03:07.29 POC72xQm.net
どれが?

391:デフォルトの名無しさん
19/12/19 16:34:48.53 dMnFAlGo.net
お題
MY FAVORITE SONGS を、Snake, Camel, Pascal にして!
my_favorite_songs, myFavoriteSongs, MyFavoriteSongs

392:デフォルトの名無しさん
19/12/19 17:08:15.12 0uPukb6z.net
>>346
Kotlin script
ただ馬鹿正直に抜き出して足すだけ。
println((1..1000).filter { it % 3 == 0 || it % 5 == 0 }.sum())

393:デフォルトの名無しさん
19/12/19 17:42:54.73 0uPukb6z.net
>>383
Kotlin
URLリンク(paiza.io)

394:デフォルトの名無しさん
19/12/19 19:39:18.71 xlnTqgd4.net
>>383 Ruby
str = 'MY FAVORITE SONGS'
puts str.tr('A-Z ', 'a-z_') # => my_favorite_songs
puts str.gsub(/ (\w)/){$1.downcase}.swapcase # => myFavoriteSongs
puts str.split.map(&:capitalize).join # => MyFavoriteSongs

395:デフォルトの名無しさん
19/12/19 20:42:11.68 M6N2QgoX.net
>>351 >>362 Common Lisp
URLリンク(ideone.com)
30億バイトでの実行結果:
% uname -p
Intel(R) Core(TM) i7-4765T CPU @ 2.00GHz
% /usr/bin/time -p sbcl --script odai-pt16-351-362-lisp-3-hash-table.lisp </tmp/random-acgt-3-billion.txt
((#\T . 17))
real 178.75
user 177.55
sys 1.17
%
*standard-input* ではなく (open "/dev/stdin" ...) を使っているのは *standard-input* が遅いから
ざっと六倍もの時間がかかった

396:デフォルトの名無しさん
19/12/19 21:46:59.61 XnN+NvoA.net
>>383
R
URLリンク(ideone.com)

397:デフォルトの名無しさん
19/12/19 22:59:23.08 L7o4TfDh.net
>>371
f(m,n)≧2mn+m+n+1
が示せました
(2,2)の条件で13枚移動できます

398:383
19/12/20 14:24:42 A+TGdcd9.net
>>383
Ruby で、

ary = "MY FAVORITE SONGS".split.map( &:downcase ) # すべて小文字へ

puts ary.join( "_" ) #=> my_favorite_songs
puts ary.map( &:capitalize ).join #=> MyFavoriteSongs

puts ary.map.with_index { |word, idx|
if idx == 0
word # 最初だけ、そのまま
else
word.capitalize
end
}.join #=> myFavoriteSongs

399:デフォルトの名無しさん
19/12/20 17:55:37.64 KHh/7LOP.net
>>346 julia
println(sum(Set([3:3:1000; 5:5:1000])))

400:デフォルトの名無しさん
19/12/20 19:38:12.53 KibkA5Ab.net
お題(>>346の改変版)
1から100万までの整数のうち、2か3か5か7か11か13か17か19の倍数の合計を
求める処理を3000回繰り返してから、結果を表示せよ。ただし、ideoneの
実行制限時間(5秒)以内に完了すること。

401:デフォルトの名無しさん
19/12/20 20:40:12.54 l1czkVGZ.net
>>392 C++
URLリンク(ideone.com)

402:デフォルトの名無しさん
19/12/20 21:09:48.70 ZH5ZbPnE.net
今アップしようと思ったら
>>393とそっくりだった

403:デフォルトの名無しさん
19/12/20 21:22:01.32 ZH5ZbPnE.net
素数の数をカウントする代わりに
マイナスを付けて素数を掛け算してるのが違うくらい

404:デフォルトの名無しさん
19/12/20 21:28:45.69 ZH5ZbPnE.net
お題
3000回じゃなくてもっとマシな出し方なかったのかね?
最適化で1回の結果を使い回されて何回やっても時間同じになっちゃってたよ
3000回数分合計して、最後に3000で割ってたんだけど
最適化が頭良すぎた

405:デフォルトの名無しさん
19/12/20 21:49:16.14 qHTdS2+z.net
やったー僕が考えた効率良いプログラムだと5秒以内で3000回も計算できたぞ!
そうだこれを


406:お題にしてやろう!



407:デフォルトの名無しさん
19/12/20 22:16:29.10 ZH5ZbPnE.net
C/C++だと
ほんのちょっと数学の知識を使えば
コード上の工夫をまったくしなくても0.01秒
コード上の工夫でまだまだ速くなる
スクリプト系言語でも100倍はかからない気がする
なぜ5秒?
なぜ1000000?
なぜ3000回?
謎だ

408:デフォルトの名無しさん
19/12/20 22:30:48.36 fz/tpFJr.net
些末な最適化など
数学的知識に基づくオーダーの低減に比べたらむなしい

409:デフォルトの名無しさん
19/12/20 22:30:49.77 ZH5ZbPnE.net
数学的知識を使わないで
単純に足していくアルゴリズムを
コードの工夫で5秒切るって問題?

410:デフォルトの名無しさん
19/12/20 22:38:11.88 PCNOOvYP.net
>>399
>>393は素数の数に対してオーダーは2^n nだけど、
コード上の工夫で2^nになる
さらに、
乗算の数十倍時間がかかる、変数による除算も
コード上の工夫で無くせる
些細な差では無いと思う

411:デフォルトの名無しさん
19/12/20 22:38:43.75 ZH5ZbPnE.net
>>399
>>393は素数の数に対してオーダーは2^n nだけど、
コード上の工夫で2^nになる
さらに、
乗算の数十倍時間がかかる、変数による除算も
コード上の工夫で無くせる
些細な差では無いと思う

412:デフォルトの名無しさん
19/12/20 22:39:52.16 ZH5ZbPnE.net
ダブった

413:デフォルトの名無しさん
19/12/20 22:50:38.46 qHTdS2+z.net
数学も計算機学もどっちも大事

414:デフォルトの名無しさん
19/12/20 23:00:03.89 KibkA5Ab.net
>>393
正解。ちなみにRで短く書いたプログラム: URLリンク(ideone.com)
結局、奇数個の積の倍数の個数の和から偶数個のそれを引くというやり方は同じだな。
>>397
そう。上のプログラムが5秒以内に余裕を持って終わるように繰り返し回数を設定したw
効率というより短いのが好きで書いた。
>>398
>>393をRにそのまま移植すると5秒以内に終わらず、1000回に減らしても
URLリンク(ideone.com))4.56秒かかって、上のプログラムの2.43秒より
遅いよ。Rでは自前のループを書くよりも、関数や演算子を使って短く書いた方が
速くなることが多い。

415:デフォルトの名無しさん
19/12/20 23:06:22.58 ZH5ZbPnE.net
>>405
Rだと3桁倍も時間がかかるのか
衝撃

416:デフォルトの名無しさん
19/12/20 23:10:59.45 KibkA5Ab.net
1000までではなく与えられた自然数までということ以外は>>346と同じ問題が
オライリーの「Modern C++チャレンジ」に載っているが、示されている解答は
if (i % 3 == 0 || i % 5 == 0) sum += i; という単純に足していく方式だな。
本の副題は「C++17プログラミング力を鍛える100問」だが、何が鍛えられられるのか
よく分からない。

417:デフォルトの名無しさん
19/12/20 23:11:25.23 ZH5ZbPnE.net
C/C++で1秒かかる問題は
C/C++限定になっちゃう感じだね

418:デフォルトの名無しさん
19/12/20 23:14:31.11 ZH5ZbPnE.net
>>407
算数やアルゴリズムじゃなくて
言語の勉強ってことでしょ

419:デフォルトの名無しさん
19/12/21 05:43:11.08 vVh8rrgH.net
連投アスペ君うざいよ
学歴詐称までしてたみたいだけど

420:デフォルトの名無しさん
19/12/21 17:30:00.35 BSqycIZI.net
お題
ビットコインの採掘問題です
000 〜 300 までの3桁の整数の文字列を、MD5 で暗号化した時に、
冒頭部分から、5 が最も多く続く、整数は何?
答え、239 : 555d6〜

421:デフォルトの名無しさん
19/12/21 21:23:49.40 WOeaPgYE.net
>>411
Java
URLリンク(paiza.io)

422:デフォルトの名無しさん
19/12/21 22:58:23.57 hbXQRpYW.net
>>411 PowerShell
$MD5 = new-object "System.Security.Cryptography.MD5CryptoServiceProvider"
$a = 0..3


423:00 $hash = $a |% {-join ($MD5.ComputeHash([char[]]("{0:000}" -f $_)) |% {"{0:x2}" -f $_})} $n = $hash |% {[RegEx]::Match($_, "^5+").length} $max = ($n | measure -max).Maximum $a |? {$n[$_] -eq $max} |% {"$_ : " + $hash[$_]} -- 実行結果 -- 239 : 555d6702c950ecb729a966504af0a635



424:デフォルトの名無しさん
19/12/22 03:50:07 lBW/6Z3k.net
>>411
Kotlin
URLリンク(paiza.io)

425:デフォルトの名無しさん
19/12/22 14:00:57.91 sfBU8dhx.net
>>411 Ruby
require 'digest'
p ("000".."300").map{|i|[Digest::MD5.hexdigest(i).index(/[^5]/),i]}.max[1]

426:411
19/12/22 19:20:37.12 u+b66RrE.net
>>411 Ruby
require 'digest'
# :count は、先頭から続く、5の数
Result = Struct.new( :num, :md5, :count )
res = ( "000".."300" ).each_with_object( Result.new( nil, nil, -1 ) ) do |num, res|
md5 = Digest::MD5.hexdigest( num ) # ハッシュ化
md5.each_char.with_index do |char, idx| # 1文字ずつ処理する
if char != "5"
if idx > res.count # 大きい時だけ更新する
res.num = num
res.md5 = md5
res.count = idx
end
break
end
end
end
puts "#{ res.num } : #{ res.md5 }"
#=> 239 : 555d6702c950ecb729a966504af0a635

427:デフォルトの名無しさん
19/12/23 15:49:57.54 8tSOZ4fL.net
>>411
Perl5
URLリンク(paiza.io)

428:デフォルトの名無しさん
19/12/24 02:05:20.47 3/kDRwCG.net
>>377
>>389
・n=13 のとき
 条件(2,2)
{12345678} = A, {9,10} = B, 11=C, 12=D, 13=E と略記する。
 ABCDE, -, -, -
  手順1
 CDE, -, -, AB
  手順2
 CD, E, -, AB
 ACD, E, -, B
  手順3
 ACD, -, -, BE
 CD, -, -, ABE
  手順2
 C, D, -, ABE
 AC, D, -, BE 
  手順3
 AC, -, -, BDE
 C, -, -, ABDE
 -, C, -, ABDE
 A, C, -, BDE
  手順3
 A, -, -, BCDE
 -, -, -, ABCDE
にて可能。

429:デフォルトの名無しさん
19/12/24 02:16:33.78 3/kDRwCG.net
 #A = f(2,1) = 8,   #B = 2
* 手順1
 ABX, -, -, -
 BX, -, -, A
 OX, 9, -, A
 AOX, 9, -, -
 AOX, -, -, 9
 OX, -, -, A9
 X, O, -, A9
 AX, O, -, 9
 AX, O, 9, -
 AX, -, 9, O
 AX, -, -, B
 X, -, -, AB
*手順2
 CDY, -, -, *
 DY, C, -, *
 Y, C, D, *
 Y, -, CD, *
 -, Y, CD, *
 -, CY, D, *
 D, CY, -, *
 CD, Y, -, *
* 手順3
 *, Y, -, BZ
 *, 9Y, -, OZ
 *, 9Y, O, Z
 *, Y, B, Z
 *, -, B, YZ
 *, 9, O, YZ
 *, 9, -, OYZ
 *, -, -, BYZ

430:デフォルトの名無しさん
19/12/24 06:16:15 cUFUrp77.net
おめでとう
次は(2,2,2)

431:デフォルトの名無しさん
19/12/24 06:33:05.83 cUFUrp77.net
n=13を考えるとき
真ん中2本が空いてる時にはn=12までは動かせる
っていう仮定を使うと
考え方が楽になりますよ
これが出来たら
あとは(2,1)のn=8から1枚ずつ増やしていく帰納法が使えます

432:デフォルトの名無しさん
19/12/24 07:26:03.90 cUFUrp77.net
a≧b≧c≧d≧e≧1
f(a,b,c,d,e)=f(a-1,b,c,d,e)+2n+1
n = max { a, f(b-1,c,d,e) }
+ max { b, f(c-1,d,e) }
+ max { c, f(d-1,e) }
+ e

433:デフォルトの名無しさん
19/12/24 07:43:48.05 cUFUrp77.net
(a,b,c,d,e) の動かしかた
A : 小さい f(a-1,b,c,d,e) 枚
X : 最大の1枚
(n) : A,X以外の任意のn枚
n : >>422で定義
A(2n)X / - / -
(n)X / - / A(n)
(n) / X / A(n)
A(n) / X / (n)
A(n) / - / (n)X
- / - / A(2n)X

434:デフォルトの名無しさん
19/12/24 07:48:24.24 cUFUrp77.net
ミスった
n = min { a, f(b-1,c,d,e) }
+ min { b, f(c-1,d,e) }
+ min { c, f(d-1,e) }
+ e

435:デフォルトの名無しさん
19/12/24 19:47:21.14 cUFUrp77.net
動かせる枚数だけですがコードにしました
URLリンク(ideone.com)

436:デフォルトの名無しさん
2019/12/25


437:(水) 16:51:57.78 ID:eBvDhPt7.net



438:デフォルトの名無しさん
19/12/25 19:05:13.68 LrSoTBV6.net
2) 3) は瞬時だけど
1) は難しい
出題者は出来たんだよね?

439:426
19/12/25 19:20:25.05 eBvDhPt7.net
>>427
1)は二年前の大晦日に、part9で ほぼ既出問題。
とても大きな数字になるから、
全探索しないでね、って意味で1)においたのだが……

440:デフォルトの名無しさん
19/12/25 22:46:56.00 LrSoTBV6.net
URLリンク(ideone.com)

441:デフォルトの名無しさん
19/12/25 22:48:16.07 LrSoTBV6.net
合ってる?

442:デフォルトの名無しさん
19/12/25 22:57:35.89 LrSoTBV6.net
辞書順最後は
{ 53, 59, 61, 67, 71, 73, 83, 89, 97, 101, 103, 107, 109, 113, 127, 131, 137, 139, 149, 151 }

443:426
19/12/25 23:33:28.28 eBvDhPt7.net
>>429, 431 当方とおなじです。
>>426
 URLリンク(ideone.com)
数が程々なので、まとめて手抜きの"文字列DP"をやってます。
(pypyで1秒以内で回っているのだから、真面目にやる必要ないでしょう)

444:デフォルトの名無しさん
19/12/26 01:18:40.30 rIhsLdYp.net
がんばって速くしてみたけどあまり速くならなかった
URLリンク(ideone.com)

445:デフォルトの名無しさん
19/12/26 01:28:39.37 rIhsLdYp.net
C++だから速いはず
だけど大差無いって事は
アルゴリズムで負けてる?

446:デフォルトの名無しさん
19/12/26 04:04:05.93 Wc5llTmi.net
>>421
>>418>>371 にEを追加したものです。
 ピン0⇔ピン3 間で移動する「4ピン手順」と
 ピン{{0,1,2} または {1,2,3} 間で移動する「3ピン手順」
 を交互に行ないます。
*手順1 は4ピン手順で、ABの10個を移動します。
*手順2、手順3 は3ピン手順です。
  ピン0→ピン{1,2} あるいはピン{1,2}→ピン3 間でxを移動するときは
  xより小さい円盤を1本のピンに集めることが必要で、これがネックですね。
  最初に12個移動するのはどうかと思うけど・・・・

447:デフォルトの名無しさん
19/12/26 07:13:27.63 rIhsLdYp.net
>>435
帰納法を使えば
具体的な手順は>>423の手順だけで
≧を示せる
と言ってるだけですよ
帰納法の仮定として
>>422の式より円盤の枚数が少ない時は動かせる
>>422の条件より置ける置ける枚数が少ない時は>>422が成り立つ
を使う


次ページ
最新レス表示
スレッドの検索
類似スレ一覧
話題のニュース
おまかせリスト
▼オプションを表示
暇つぶし2ch

1355日前に更新/270 KB
担当:undef