回答編集履歴

3

修正

2018/09/05 17:21

投稿

LouiS0616
LouiS0616

スコア35660

test CHANGED
@@ -158,8 +158,6 @@
158
158
 
159
159
  import itertools
160
160
 
161
- import math
162
-
163
161
 
164
162
 
165
163
 

2

追記

2018/09/05 17:21

投稿

LouiS0616
LouiS0616

スコア35660

test CHANGED
@@ -145,3 +145,67 @@
145
145
 
146
146
 
147
147
  イケてない部分もありますが、しっかり動いてるのでまずは充分でしょう。
148
+
149
+
150
+
151
+ 書いてみた
152
+
153
+ ---
154
+
155
+ 他の回答に対抗して、『ifとforだけ』縛りを無視して書いてみた。
156
+
157
+ ```Python
158
+
159
+ import itertools
160
+
161
+ import math
162
+
163
+
164
+
165
+
166
+
167
+ def is_prime(num, prime_list):
168
+
169
+ return all(num % prime != 0 for prime in prime_list)
170
+
171
+
172
+
173
+ def gen_primes():
174
+
175
+ prime_list = [2]
176
+
177
+
178
+
179
+ yield 2
180
+
181
+ for num in itertools.count(start=3, step=2):
182
+
183
+ if is_prime(num, prime_list):
184
+
185
+ prime_list.append(num)
186
+
187
+ yield num
188
+
189
+
190
+
191
+
192
+
193
+ if __name__ == '__main__':
194
+
195
+ gen = gen_primes()
196
+
197
+
198
+
199
+ for _ in range(1999):
200
+
201
+ next(gen)
202
+
203
+
204
+
205
+ print(
206
+
207
+ next(gen)
208
+
209
+ )
210
+
211
+ ```

1

追記

2018/09/05 17:18

投稿

LouiS0616
LouiS0616

スコア35660

test CHANGED
@@ -95,3 +95,53 @@
95
95
 
96
96
 
97
97
  以上で完成です。
98
+
99
+
100
+
101
+ 追記: nobitaさんが完成させたプログラム
102
+
103
+ ---
104
+
105
+ ```Python
106
+
107
+ a = 0
108
+
109
+ b = 1
110
+
111
+ q = []
112
+
113
+ w = []
114
+
115
+ i = 0
116
+
117
+
118
+
119
+
120
+
121
+ for aa in range(1,100):
122
+
123
+ j = 0
124
+
125
+ for i in range(1,100):
126
+
127
+
128
+
129
+ if aa % i == 0:
130
+
131
+
132
+
133
+ j += 1
134
+
135
+ if 2 < j:
136
+
137
+ print(f"{aa}は素数ではない")
138
+
139
+ else:
140
+
141
+ print(f"{aa}は素数である")
142
+
143
+ ```
144
+
145
+
146
+
147
+ イケてない部分もありますが、しっかり動いてるのでまずは充分でしょう。