Jumlah Urutan Rantai

16

Urutan:

  1. Kita mulai dari 1.
  2. Kami pertama-tama menambahkan nilai 1-diindeks saat ini ke nomor sebelumnya dalam urutan.
  3. Kemudian kami menerapkan operasi matematika berikut jika berlaku untuk nilai saat ini:
    • Dibagi oleh 2? => Penambahan
    • Dibagi oleh 3? => Pengurangan
    • Dibagi oleh 4? => (Penambahan DAN) Multiply
    • Tidak bisa dibagi dengan tidak 2, 3juga tidak 4? -> Lanjutkan dengan jumlah hasil saat ini

Keluaran:

Keluarkan 100 angka pertama dalam urutan ini:

1, 1, 21, 25, 30, 216, 223, 223, 2169, 2179, 2190, 2202, 2215, 2215, 2245, 2261, 2295, 2295, 2333, 2353, 2395, 2417, 56649, 56649, 56699, 56725, 1533033, 1533061, 1533090, 45993600, 45993631, 45993631, 1517792001, 1517792035, 1517792070, 1517792106, 1517792143, 1517792143, 1517792221, 1517792261, 1517792343, 1517792343, 1517792429, 1517792473, 1517792563, 1517792609, 71336257041, 71336257041, 71336257139, 71336257189, 3638149121841, 3638149121893, 3638149121946, 196460052588000, 196460052588055, 196460052588055, 11198222997525633, 11198222997525691, 11198222997525750, 11198222997525810, 11198222997525871, 11198222997525871, 11198222997525997, 11198222997526061, 11198222997526191, 11198222997526191, 11198222997526325, 11198222997526393, 11198222997526531, 11198222997526601, 795073832824398753, 795073832824398753, 795073832824398899, 795073832824398973, 59630537461829934225, 59630537461829934301, 59630537461829934378, 4651181922022734887568, 4651181922022734887647, 4651181922022734887647, 376745735683841525912529, 376745735683841525912611, 376745735683841525912694, 376745735683841525912778, 376745735683841525912863, 376745735683841525912863, 376745735683841525913037, 376745735683841525913125, 376745735683841525913303, 376745735683841525913303, 376745735683841525913485, 376745735683841525913577, 376745735683841525913763, 376745735683841525913857, 35790844889964944961834465, 35790844889964944961834465, 35790844889964944961834659, 35790844889964944961834757, 3543293644106529551221660545, 3543293644106529551221660645

Berikut adalah 10 angka pertama dalam urutan dengan penjelasan:

// Starting number of the sequence:
1

// 1 (previous number in the sequence)
// + 2 (current index in 1-indexed sequence)
// = 3 -> 3 - 2 (3 is divisible by 3, so we subtract the current index 2)
// = 1
1

// 1 (previous number in the sequence)
// + 3 (current index in 1-indexed sequence)
// = 4 -> 4 + 3 (4 is divisible by 2, so we first add the current index 3)
// = 7 -> 7 * 3 (and 4 is also divisible by 4, so we then also multiply the current index 3)
// = 21
21

// 21 (previous number in the sequence)
// + 4 (current index in 1-indexed sequence)
// = 25 (25 is not divisible by 2, 3 nor 4)
25

// 25 (previous number in the sequence)
// + 5 (current index in 1-indexed sequence)
// = 30 -> 30 + 5 (30 is divisible by 2, so we first add the current index 5)
// = 35 -> 35 - 5 (and 30 is also divisible by 3, so we then also subtract the current index 5)
// = 30
30

// 30 (previous number in the sequence)
// + 6 (current index in 1-indexed sequence)
// = 36 -> 36 + 6 (36 is divisible by 2, so we first add the current index 6)
// = 42 -> 42 - 6 (and 36 is also divisible by 3, so we then also subtract the current index 6)
// = 36 -> 36 * 6 (and 36 is also divisible by 4, so we then also multiply the current index 6)
// = 216
216

// 216 (previous number in the sequence)
// + 7 (current index in 1-indexed sequence)
// = 223 (223 is not divisible by 2, 3 nor 4)
223

// 223 (previous number in the sequence)
// + 8 (current index in 1-indexed sequence)
// = 231 -> 231 - 8 (231 is divisible by 3, so we subtract the current index 8)
// = 223
223

// 223 (previous number in the sequence)
// + 9 (current index in 1-indexed sequence)
// = 232 -> 232 + 9 (232 is divisible by 2, so we first add the current index 9)
// = 241 -> 241 * 9 (and 232 is also divisible by 4, so we then also multiply the current index 9)
// = 2169
2169

// 2169 (previous number in the sequence)
// + 10 (current index in 1-indexed sequence)
// 2179 (2179 is not divisible by 2, 3 nor 4)
2179

Aturan tantangan:

  • Jika bahasa Anda tidak mendukung apa pun yang lebih besar dari 2 31 -1, Anda dapat melanjutkan urutan hingga maks itu (jadi 46 angka pertama, hingga - dan termasuk - 1,517,792,609).
  • Format output fleksibel. Anda dapat mengembalikan array atau daftar, string yang dipisahkan dengan spasi, koma, dll. Panggilan Anda.

Aturan umum:

  • Ini adalah , jadi jawaban tersingkat dalam byte menang.
    Jangan biarkan bahasa kode-golf mencegah Anda memposting jawaban dengan bahasa non-codegolf. Cobalah untuk memberikan jawaban sesingkat mungkin untuk bahasa pemrograman 'apa saja'.
  • Aturan standar berlaku untuk jawaban Anda, jadi Anda diperbolehkan menggunakan STDIN / STDOUT, fungsi / metode dengan parameter yang tepat, program lengkap. Panggilanmu.
  • Celah default tidak diperbolehkan.
  • Jika memungkinkan, tambahkan link dengan tes untuk kode Anda.
  • Juga, silakan tambahkan penjelasan jika perlu.
Kevin Cruijssen
sumber
Apakah kita menampilkan nilai n, nilai n pertama, atau hanya sampai ukuran integer maks kita?
Gabriel Benamy
@GabrielBenamy 100 pertama dalam urutan.
Kevin Cruijssen
1
Saya cukup yakin Anda hanya memiliki 99 nomor di blok itu.
Kade
2
Jawaban saya tidak setuju dengan hasil Anda hanya pada 13 angka terakhir.
Gabriel Benamy
1
@ Shang Tetap
Kevin Cruijssen

Jawaban:

1

05AB1E , 24 23 byte

-1 byte terima kasih kepada Kevin Crujissen

¼¾тF=¼¾+©…+-*v®NÌÖi¾y.V

Cobalah online!

Penjelasan:

¼¾                        # set the counter to 1, then push 1
  тF                      # repeat the following 100 times
    =                     # print the current number in the sequence
     ¼¾                   # increment the counter
       +                  # add it to the current number
        ©                 # save the result in the register
         …+-*v            # for each of '+', '-', and '*'...
              ®   i       # if the register...
                 Ö        # is divisible by...
               NÌ         # the loop index + 2...
                   ¾y.V   # then apply the current operation
Grimmy
sumber
1
Mencoba menemukan sesuatu yang lebih pendek dengan variabel penghitung sehingga UXdapat dihapus, tapi saya tidak bisa. Saya berakhir pada 24 byte juga karena itu dimulai pada 0bukan 1. Saya sekarang meningkatkannya sebelum sementara, tetapi kemudian kita harus mengulang 101kali bukan 100.. Ah well.
Kevin Cruijssen
@KevinCruijssen ya, itu UXmerusak pemandangan. Aku mencoba untuk menyingkirkan itu untuk sementara dan berakhir dengan sekelompok 24 dan 25 variasi: 1тF=NÌ©+DÑ3L>Ãv®…-*+yè.V, 1тL>v=y+©3F®NÌÖiy…+-*Nè.V... saya tidak mempertimbangkan menggunakan variabel counter, ini menarik.
Grimmy
1
@KevinCruijssen 24 Anda menginspirasi 23: gunakan saja тFalih-alih Ƶ0µ. Saya sudah mengeditnya, terima kasih! (PS: harus benar-benar ada byte tunggal ¼¾...)
Grimmy
Ah bagus. Kupikir kau akan menemukan sesuatu, haha. ;) Dan ya, satu byter untuk ¼¾akan menyenangkan, walaupun jujur ​​saja, saya hampir tidak pernah menggunakannya seperti itu. Single-byte builtin yang paling saya sukai saat ini adalah ©®variabel kedua yang tidak muncul. Mungkin mulai dari string kosong ""seperti yang Anda sebutkan dalam tantangan lain sebelumnya.
Kevin Cruijssen
8

R, 85 82 79 76 72 70 byte

for(i in 2:56)T[i]=((z=i+T[i-1])+i*(!z%%2)-i*(!z%%3))*`if`(z%%4,1,i);T

ungolfed:

s=1 ## formerly s=1:56, formerly s=1:100
for(i in 2:56){
    z=i+s[i-1]
    s[i]=(z+i*(z%%2<1)-i*(z%%3<1))*(1+(i-1)*(z%%4<1))
}
s

Terima kasih kepada @rturnbull untuk menunjukkan bahwa saya dapat menggunakan (!z%%3)alih-alih (z%%3<1)memeriksa moduli, dan bahwa definisi zsuatu terjadi ketika pertama kali digunakan.

Bermain golf 3-4 karakter dengan menyalahgunakan ekstensi vektor: jawabannya awalnya dimulai s=1:56...tetapi kita tidak perlu melakukan itu, panjangnya sakan diperpanjang sesuai kebutuhan.

Disimpan 3 byte lebih banyak dengan mengganti kondisi terakhir dengan panggilan ke "if"fungsi (ya, itu fungsi yang tepat di R!)

Disimpan 4 byte lebih banyak dengan mengganti sdengan T, yang merupakan builtin sama dengan TRUEyang juga sama dengan 1. Saya menyadarinya pada saat yang sama dengan @rturnbull (jujur!)

Ini memang menderita beberapa masalah numerik setelah kami melebihi 2 ^ 52, tetapi tidak ada yang bisa saya lakukan tentang hal itu --- R hanya dapat menggunakan double tipe untuk angka yang lebih besar dari 2^31-1, tetapi mereka menyimpan bilangan bulat hingga 2 ^ 52 persis. Jadi, saya diizinkan untuk hanya menampilkan 56 syarat pertama (istilah terakhir yaitu "benar") yang menyimpan satu byte dari case 100-length.

Inilah output dari versi 56-length:

    > for(i in 2:56){z=i+T[i-1];T[i]=(z+i*(!z%%2)-i*(!z%%3))*`if`(z%%4,1,i)};T
 [1]               1               1              21              25              30             216
 [7]             223             223            2169            2179            2190            2202
[13]            2215            2215            2245            2261            2295            2295
[19]            2333            2353            2395            2417           56649           56649
[25]           56699           56725         1533033         1533061         1533090        45993600
[31]        45993631        45993631      1517792001      1517792035      1517792070      1517792106
[37]      1517792143      1517792143      1517792221      1517792261      1517792343      1517792343
[43]      1517792429      1517792473      1517792563      1517792609     71336257041     71336257041
[49]     71336257139     71336257189   3638149121841   3638149121893   3638149121946 196460052588000
[55] 196460052588055 196460052588055
JDL
sumber
1
Saya akan mengatakan perulangan hanya sampai 56 adalah permainan yang adil diberikan deskripsi tantangan.
Billywob
@ Billywob memang benar. Dalam uraian saya nyatakan " Jika bahasa Anda tidak mendukung apa pun yang lebih besar dari 2 ^ 31-1, Anda dapat melanjutkan urutan sampai maks (jadi 46 angka pertama, sampai - dan termasuk - 1,517,792,609). ", Tapi ini dari Tentu saja juga berlaku untuk nomor yang berbeda dari 32-bit. Jika R tidak dapat menangani sesuatu yang lebih besar, dari 56 angka pertama benar-benar baik-baik saja. Dan ya, jika Anda tahu itu tidak pernah bisa di atas 56, Anda dapat mengubah 100to 56untuk menyimpan byte.
Kevin Cruijssen
1
Anda dapat menyimpan tiga byte dengan mengubah z%%2<1(dan seterusnya) !z%%2, menyalahgunakan konversi tipe implisit.
rturnbull
Terima kasih @urnbull, untuk beberapa alasan saya pikir !tidak mengalahkan %%, tetapi ternyata itu berhasil!
JDL
2
Anda juga dapat menyalahgunakan Tdan menggunakannya di tempat s, memungkinkan Anda untuk menghapus s=1;, menyimpan empat byte lagi. Dimungkinkan untuk melipat definisi zmenjadi definisi s[i](yah, T[i]sekarang), seperti:, T[i]=((z=i+T[i-1])+ ...yang berarti bahwa Anda dapat kehilangan kurung keriting, menghemat beberapa byte lagi. EDIT: Oh, saya melihat bahwa Anda melakukan Ttrik ketika saya sedang menulis komentar saya! Pikiran besar berpikir sama, kata mereka.
rturnbull
5

Python 3, 82 78 76 74 72 byte

i=s=1
exec('print(s);i+=1;s+=i;s=(s+i-i*(s%2+(s%3<1)))*i**(s%4<1);'*100)

Keluaran:

1
1
21
25
30
216
223
223
2169
2179
2190
2202
2215
2215
2245
2261
2295
2295
2333
2353
2395
2417
56649
56649
56699
56725
1533033
1533061
1533090
45993600
45993631
45993631
1517792001
1517792035
1517792070
1517792106
1517792143
1517792143
1517792221
1517792261
1517792343
1517792343
1517792429
1517792473
1517792563
1517792609
71336257041
71336257041
71336257139
71336257189
3638149121841
3638149121893
3638149121946
196460052588000
196460052588055
196460052588055
11198222997525633
11198222997525691
11198222997525750
11198222997525810
11198222997525871
11198222997525871
11198222997525997
11198222997526061
11198222997526191
11198222997526191
11198222997526325
11198222997526393
11198222997526531
11198222997526601
795073832824398753
795073832824398753
795073832824398899
795073832824398973
59630537461829934225
59630537461829934301
59630537461829934378
4651181922022734887568
4651181922022734887647
4651181922022734887647
376745735683841525912529
376745735683841525912611
376745735683841525912694
376745735683841525912778
376745735683841525912863
376745735683841525912863
376745735683841525913037
376745735683841525913125
376745735683841525913303
376745735683841525913303
376745735683841525913485
376745735683841525913577
376745735683841525913763
376745735683841525913857
35790844889964944961834465
35790844889964944961834465
35790844889964944961834659
35790844889964944961834757
3543293644106529551221660545
3543293644106529551221660645

Saran dipersilahkan!

TheNumberOne
sumber
4

05AB1E , 34 31 30 byte

XTnFD,NÌ©+D3L>%_`X®‚sèrŠs-®*+*

Cobalah online!

Penjelasan

X                               # initialize stack with 1
 TnF                            # for N in [0 ... 99]
    D,                          # print a copy of top of stack
      NÌ©                       # increase index N by 2 and store in register
         +                      # add this to current value
          D                     # make a copy of the current value
           3L>                  # push the list [2,3,4]
              %                 # take current value mod elements in list
               _                # invert this
                `               # push the elements from the list to stack
                 X®‚sè          # index into list [1,N+2] with the result of mod 4
                      rŠs-      # subtract result of mod 3 from result of mod 2
                          ®*    # multiply by N+2
                            +   # add this to current value
                             *  # multiply current value with the result from index operation
Emigna
sumber
3

Python 2, 76 Bytes

Implementasi cukup standar, saya pikir menggunakan pernyataan exec daripada loop sementara disimpan 2 byte atau lebih. Metode rekursif mungkin lebih pendek, saya membayangkan xnor akan segera muncul;)

n=1
f=1
exec'print f;n+=1;d=f+n;f=(d+n*(d%2<1)-n*(d%3<1))*[1,n][d%4<1];'*100

Jika saya menggunakan pembaruan yang TheNumberOne temukan, saya akan berada di 69 byte (tapi kemudian saya akan menyalin)

n=f=1;exec'print f;n+=1;d=f+n;f=(d+n-n*(d%2+(d%3<1))*n**(d%4<1);'*100

Keluaran:

1
1
21
25
30
216
223
223
2169
2179
2190
2202
2215
2215
2245
2261
2295
2295
2333
2353
2395
2417
56649
56649
56699
56725
1533033
1533061
1533090
45993600
45993631
45993631
1517792001
1517792035
1517792070
1517792106
1517792143
1517792143
1517792221
1517792261
1517792343
1517792343
1517792429
1517792473
1517792563
1517792609
71336257041
71336257041
71336257139
71336257189
3638149121841
3638149121893
3638149121946
196460052588000
196460052588055
196460052588055
11198222997525633
11198222997525691
11198222997525750
11198222997525810
11198222997525871
11198222997525871
11198222997525997
11198222997526061
11198222997526191
11198222997526191
11198222997526325
11198222997526393
11198222997526531
11198222997526601
795073832824398753
795073832824398753
795073832824398899
795073832824398973
59630537461829934225
59630537461829934301
59630537461829934378
4651181922022734887568
4651181922022734887647
4651181922022734887647
376745735683841525912529
376745735683841525912611
376745735683841525912694
376745735683841525912778
376745735683841525912863
376745735683841525912863
376745735683841525913037
376745735683841525913125
376745735683841525913303
376745735683841525913303
376745735683841525913485
376745735683841525913577
376745735683841525913763
376745735683841525913857
35790844889964944961834465
35790844889964944961834465
35790844889964944961834659
35790844889964944961834757
3543293644106529551221660545
3543293644106529551221660645
Kade
sumber
3

JavaScript, 75 63 byte

for(n=p=0;n++<57;alert(p=p%4?q:q*n))q=(p+=n)%2?p:p+n,q-=p%3?0:n

Versi lain:

for(n=p=0;n++<57;)alert(p=((p+=n)+(!(p%2)-!(p%3))*n)*(p%4?1:n))

Keduanya berhenti di indeks 57 (diindeks 0) karena saat itulah output melampaui ukuran angka aman JavaScript (2 53 - 1). Ternyata loop jauh lebih pendek daripada fungsi rekursif, bahkan dengan ES6:

f=(n=0,p=0)=>n++>56?[]:(q=(p+=n)%2?p:p+n,q-=p%3?0:n,[q*=p%4?1:n,...f(n,q)])

Yang ini mengembalikan array dari 57 elemen pertama.

Produksi ETH
sumber
Saya pikir Anda harus menghindari pergi di atas ~ 50-60 karena Anda melebihi Number.MAX_SAFE_INTEGER, dan divisi Anda akan menjadi salah. Saya juga mencoba mapversi untuk kelengkapan dan itu juga clock pada 75 byte.
Neil
@Neil Ah, terima kasih. Lebih tepatnya, ini melampaui Number.MAX_SAFE_INTEGER setelah 57 entri.
ETHproduksi
3

Brain-Flak 476 466 462 456 446 Bytes

Disimpan 6 byte berkat Wheat Wizard

(((((((())<>()(())()){}){}){}())){}{}){({}[()]<(((({})<>({}())<>))<({}(()())(<()>)){({}[()]<(({}()[({})])){{}(<({}({}))>)}{}>)}({}{}<{}(())>){((<{}{}>))}{}{(<{}({}<>({})<>)>)}{}>)(({})<({}(()()())(<()>)){({}[()]<(({}()[({})])){{}(<({}({}))>)}{}>)}({}{}<{}(())>){((<{}{}>))}{}{(<{}({}<>[({})]<>)>)}{}>)({}(()()()())(<()>)){({}[()]<(({}()[({})])){{}(<({}({}))>)}{}>)}({}{}<{}(())>){((<{}{}>))}{}{(<{}(<>({}))({<({}[()])><>({})<>}{}<><{}>)>)}{}>)}{}

Cobalah secara Online!

Ini sangat lambat. TIO tidak dapat menangani keseluruhan 100 angka (batasnya tampaknya 22 atau 23). Jadi, contoh ini hanya menghasilkan 20 yang pertama, tetapi kode akan bekerja untuk 100 juga.

Penjelasan singkat:

      (())<>                           # push a 1 (the index) and switch stacks 
            (())                       # then push a 1 (the starting number)
((((((          ()()){}){}){}())){}{}) # and a 99 (a counter so that we only print the 
                                       # first 100 numbers)

# repeat until the counter is 0
{
  # pop the counter and push it minus 1 after:
  ({}[()]<
    # hold onto the current number plus the index (leave a copy on the stack to be printed)
    # and increment the index
    (((({})<>({}())<>))<
      # push logical not of (current mod 2)
      ({}(()())(<()>)){({}[()]<(({}()[({})])){{}(<({}({}))>)}{}>)}({}{}<{}(())>){((<{}{}>))}{}
      # if !(current mod 2) is 1, add the index
      {(<{}({}<>({})<>)>)}{}
    # push the current number back on
    >)
    # hold onto the current number
    (({})<
     # push logical not of (current mod 3)
     ({}(()()())(<()>)){({}[()]<(({}()[({})])){{}(<({}({}))>)}{}>)}({}{}<{}(())>){((<{}{}>))}{}
     # if !(current mod 3) is 1, then subtract the index
     {(<{}({}<>[({})]<>)>)}{}
    # push the current number back on
    >)
    # push logical not of (current mod 4)
    ({}(()()()())(<()>)){({}[()]<(({}()[({})])){{}(<({}({}))>)}{}>)}({}{}<{}(())>){((<{}{}>))}{}
    # if !(current mod 4) is 1, multiply by the index
    {(<{}(<>({}))({<({}[()])><>({})<>}{}<><{}>)>)}{}
  # put the counter back on
  >)
# loop until done
}
# pop the counter
{}
Riley
sumber
({}<>[({})]<>)(<()>)dapat diganti dengan(<({}<>[({})]<>)>)
Post Rock Garf Hunter
@WheatWizard Diperbarui. Terima kasih!
Riley
1

Java 7, 316 byte

import java.math.*;String c(){String r="";BigInteger t=BigInteger.ONE,x,p;for(int i=2;i<102;){r+=t+" ";p=(t=t.add(x=new BigInteger(i+++"")));t=x(p,2)?t.add(x):t;t=x(p,3)?t.subtract(x):t;t=x(p,4)?t.multiply(x):t;}return r;}boolean x(BigInteger p,int i){return p.mod(new BigInteger(i+"")).compareTo(BigInteger.ONE)<0;}

Tidak digabungkan & kode uji:

Coba di sini.

import java.math.*;
class M{
  static String c(){
    String r = "";
    BigInteger t = BigInteger.ONE,
               x,
               p;
    for(int i = 2; i < 102;){
      r += t+" ";
      p = (t = t.add(x = new BigInteger(i++ + "")));
      t = x(p, 2)
           ? t.add(x)
           : t;
      t = x(p, 3)
           ? t.subtract(x)
           : t;
      t = x(p, 4)
           ? t.multiply(x)
           : t;
    }
    return r;
  }

  public static void main(String[] a){
    System.out.println(c());
  }

  static boolean x(BigInteger p, int i){
    return p.mod(new BigInteger(i+"")).compareTo(BigInteger.ONE) < 0;
  }
}

Keluaran:

1 1 21 25 30 216 223 223 2169 2179 2190 2202 2215 2215 2245 2261 2295 2295 2333 2353 2395 2417 56649 56649 56699 56725 1533033 1533061 1533090 45993600 45993631 45993631 1517792001 1517792035 1517792070 1517792106 1517792143 1517792143 1517792221 1517792261 1517792343 1517792343 1517792429 1517792473 1517792563 1517792609 71336257041 3424140340272 3424140340321 3424140340371 3424140340473 3424140340525 3424140340631 3424140340631 3424140340741 3424140340797 3424140340911 3424140340969 202024280124133 202024280124193 202024280124315 202024280124377 12727529647843689 814561897462000192 52946523335030016705 52946523335030016771 52946523335030016905 52946523335030016973 52946523335030017111 52946523335030017111 52946523335030017253 52946523335030017253 52946523335030017399 52946523335030017473 3970989250127251321725 301795183009671100456876 301795183009671100456953 301795183009671100457031 301795183009671100457110 301795183009671100457270 301795183009671100457351 301795183009671100457433 25049000189802701337980717 25049000189802701337980801 25049000189802701337980971 25049000189802701337981057 2179263016512835016404367097 191775145453129481443584312280 17067987945328523848479003800841 1536118915079567146363110342083790 1536118915079567146363110342083790 1536118915079567146363110342083974 1536118915079567146363110342083974 144395178017479311758132372155911228 13717541911660534617022575354811575685 13717541911660534617022575354811575781 13717541911660534617022575354811575975 13717541911660534617022575354811576073 1358036649254392927085234960126346050829 
Kevin Cruijssen
sumber
1

C #, 120 Bytes

Sama seperti tidak ada orang waras yang mau bermain golf di Jawa, tidak ada orang waras yang bermain golf di C #! Tetapi mengacaukan itu, saya ingin melihat apa yang bisa saya lakukan. The 1Mgips fmenjadi desimal yang memiliki cukup presisi untuk jawaban ini tanpa saya harus menulis decimal. Selain itu, penambahan di tempat menyimpan beberapa byte pada jawaban Python saya. pada akhirnya itu masih 50 byte lebih lama.

void k(){int n=1;var f=1M;while(n<101){Console.WriteLine(f);var d=++n+f;f=(d+n*((d%2<1?1:0)-(d%3<1?1:0)))*(d%4<1?n:1);}}

Berikut versi yang lebih mudah dibaca (dan dapat dijalankan):

using System;
class P
{
    static void Main(string[]a) 
    {
        int n = 1;
        var f = 1M;
        while (n < 101) 
        {
            Console.WriteLine(f);
            var d = ++n + f;
            f = (d + n * ((d % 2 < 1 ? 1 : 0) - (d % 3 < 1 ? 1 : 0))) * (d % 4 < 1 ? n : 1);
        }
        Console.Read();
    }
}
Kade
sumber
Anda dapat bermain golf 1 byte dengan mengubah whileto fordan memasukkan int seperti ini:for(int n=1;n<101;)
Kevin Cruijssen
Anda bahkan dapat bermain golf lagi seperti ini: void k(){for(decimal f=1,d,n=1;n<101;)Console.WriteLine(f=((d=++n+f)+n*((d%2<1?1:0)-(d%3<1?1:0)))*(d%4<1?n:1));}( 112 bytes )
Kevin Cruijssen
1

Batch, 110 byte

@set n=0
@for /l %%i in (1,1,46)do @set/an=((n+=%%i)+(!(n%%2)-!(n%%3))*%%i)*(~-%%i*!(n%%4)+1)&call echo %%n%%

Menggunakan formula @ETHproductions, tetapi sedikit mengubah karena Batch tidak memilikinya ?:. Batch menggunakan bilangan bulat bertanda 32-bit sehingga loop berhenti pada 46.

Neil
sumber
1

Perl, 75 Bytes

use bigint;$a+=$_,say$a=($a+($a%2?0:$_)-($a%3?0:$_))*($a%4?1:$_)for(1..100)

Kode menghasilkan setiap nilai pada baris baru, dan menghitung semua 100 nilai.

Gabriel Benamy
sumber
-Mbigint, tidak ada tanda kurung di sekitar 1..100, dan !($a%2)*$_alih-alih ($a%2?0:$_)(sama untuk a%3..) harus menyimpan beberapa byte;)
Dada
Turunkan ke 60 byte dengan saran-saran dan beberapa pijat lainnya.
Xcali
1

Haskell, 70 64 byte

a%b=0^mod a b
n#i|s<-n+i=(s+s%2*i-s%3*i)*i^s%4
scanl1(#)[1..100]

scanl1(#)[1..100]mengembalikan daftar dengan 100 elemen pertama. Satu byte lebih sedikit jika saya bisa tetap dalam kisaran 2 ^ 31 (-> [1..46]).

scanl1seperti foldl1tetapi mengumpulkan hasil antara dalam daftar. Tes pembagian dapat dilakukan melalui fungsi helper %yang mengembalikan 0^0 = 1jika dapat dibagi dan 0^x = 0jika tidak.

nimi
sumber
1

J, 46 byte

(,{:((]^0=4|+)*(]*0=2|+)++-]*0=3|+)1+#)^:99]1x

Terapkan metode yang dijelaskan dalam tantangan.

Pemakaian

Perintah tambahan (,.~#\)digunakan untuk menambahkan indeks ke setiap nilai.

   (,.~#\) (,{:((]^0=4|+)*(]*0=2|+)++-]*0=3|+)1+#)^:99]1x
  1                            1
  2                            1
  3                           21
  4                           25
  5                           30
  6                          216
  7                          223
  8                          223
  9                         2169
 10                         2179
 11                         2190
 12                         2202
 13                         2215
 14                         2215
 15                         2245
 16                         2261
 17                         2295
 18                         2295
 19                         2333
 20                         2353
 21                         2395
 22                         2417
 23                        56649
 24                        56649
 25                        56699
 26                        56725
 27                      1533033
 28                      1533061
 29                      1533090
 30                     45993600
 31                     45993631
 32                     45993631
 33                   1517792001
 34                   1517792035
 35                   1517792070
 36                   1517792106
 37                   1517792143
 38                   1517792143
 39                   1517792221
 40                   1517792261
 41                   1517792343
 42                   1517792343
 43                   1517792429
 44                   1517792473
 45                   1517792563
 46                   1517792609
 47                  71336257041
 48                  71336257041
 49                  71336257139
 50                  71336257189
 51                3638149121841
 52                3638149121893
 53                3638149121946
 54              196460052588000
 55              196460052588055
 56              196460052588055
 57            11198222997525633
 58            11198222997525691
 59            11198222997525750
 60            11198222997525810
 61            11198222997525871
 62            11198222997525871
 63            11198222997525997
 64            11198222997526061
 65            11198222997526191
 66            11198222997526191
 67            11198222997526325
 68            11198222997526393
 69            11198222997526531
 70            11198222997526601
 71           795073832824398753
 72           795073832824398753
 73           795073832824398899
 74           795073832824398973
 75         59630537461829934225
 76         59630537461829934301
 77         59630537461829934378
 78       4651181922022734887568
 79       4651181922022734887647
 80       4651181922022734887647
 81     376745735683841525912529
 82     376745735683841525912611
 83     376745735683841525912694
 84     376745735683841525912778
 85     376745735683841525912863
 86     376745735683841525912863
 87     376745735683841525913037
 88     376745735683841525913125
 89     376745735683841525913303
 90     376745735683841525913303
 91     376745735683841525913485
 92     376745735683841525913577
 93     376745735683841525913763
 94     376745735683841525913857
 95   35790844889964944961834465
 96   35790844889964944961834465
 97   35790844889964944961834659
 98   35790844889964944961834757
 99 3543293644106529551221660545
100 3543293644106529551221660645
mil
sumber
1

Perl 6 , 62 byte

1,{((my \v=$_+my \n=++$+1)+n*(v%%2-v%%3))*(v%%4*n||1)}.../645/

Cobalah online!

BENAR-BENAR harus bekerja untuk mendapatkan jumlah byte saya di bawah solusi non-golf-bahasa lainnya.

Sean
sumber