プログラミング超初心者の質問

■ このスレッドは過去ログ倉庫に格納されています
1名無しさん
垢版 |
2021/03/26(金) 19:47:53.89ID:UdurcVDt
class Idiot:
__init__(self,x,y,z):
self.name = x
self.sex = y
self.why = z

printing_idiots(self):
print('{} is so idiot.'.format(self.name))
print('{0} is {1}.'.format(self.name,self.sex))
print('Why is he idiot,{}'.format(self.why))

setting_idiots_data(self):
print("What is idiot's name?")
self.name = input()
print("What is idiot's sex?")
self.sex = input()
if (self.sex = men):
print('Why is he idiot?')
self.why = input()
elif (self.sex = woman):
print('Why is she idiot?')
else:
print('you are a bullsit guy!')

idiot = Idiot()
idiot.setting_idiots_data()
idiot.printing_idiots()
このソースコードのイニシャライザの部分でエラーが出ている。
102デフォルトの名無しさん
垢版 |
2021/05/08(土) 21:12:25.19ID:0PNwSL0W
クラスより構造体を使うべき場面というのがよく理解できません
2021/05/08(土) 22:50:20.87ID:coBHIhPM
>>102
すべてがpublicのCの構造体と同じものを使いたい時だけど
新規に作る場合はそんなのあんまり無いよな
2021/05/09(日) 00:29:41.95ID:KmUW1giW
俺はなんで構造体じゃだめなのかわからない
105デフォルトの名無しさん
垢版 |
2021/05/09(日) 13:28:46.46ID:WMytKT+1
コンストラクタがいらないとき
2021/05/09(日) 15:32:51.48ID:Kg5tmvat
>>102
構造体を使うべきっていうより、構造体を使った方が簡単に行える処理はあるよ

C#の場合だけど、通信のデータや映像データみたいに内部構造の決まっている
一定サイズのバイトストーリームを処理するとき、読み込んだバイトストリームを
バイトオーダーやサイズを整えた構造体に、特定の手順を使ってメモリtoメモリで
複写すると簡単に扱えるようになるとか

クラスだとバイトストリームを項目ごとに一つ一つプロパティに写し取るとかするので
面倒くさいけど、構造体ならまとめて処理できる
107デフォルトの名無しさん
垢版 |
2021/05/09(日) 16:33:06.62ID:WMytKT+1
C#の構造体は使いにくい
2021/05/09(日) 18:08:58.83ID:OU2BPvjo
単純なDTOのsetterやgetterに変な処理入れたら
必ずどうしようもないバグや混乱の原因になった

制約のある構造体のほうがまだましじゃないかとおもった
2021/05/09(日) 18:17:42.40ID:OU2BPvjo
DTOの結合度は異常に低い
値として整合性がとれている必要があることはほとんどないし
その整合性も最初に値を作るときにValidationすればよく
ずっとオブジェクトとして整合性を保つような処理を入れるのは無駄な処理が走りすぎてナンセンスだ

つまり人間にとってたまたま一緒に扱いたいだけで
コンピューター上で一つのオブジェクトとして扱う理由がまったくない
これは一つ一つ別のデータをたまたま値としてまとめているのだとわかるように
構造体であるべきだとおもう
2021/05/11(火) 12:21:05.65ID:9u97i/pE
あの。しょうがくせいです
4ねんせい、
ぱいそん?xをだしたいです
2021/05/19(水) 17:00:27.27ID:j7cCaUeW
>>110
どんな感じでxを出したいか教えてくれるとありがたい。
xの中身のを表示したいのなら、

print(x)

で表示されると思う。
112デフォルトの名無しさん
垢版 |
2021/05/25(火) 01:19:14.34ID:SViyLBx8
cssについて分からない事があるので質問させて下さい。
text-alignプロパティが適用されません。
初心者なので、どこが間違っているのか分からず
困っています。
一応こんな感じです。
(htmlファイル)http://up-img.net/img.php?mode=png&;id=20994
(cssファイル)http://up-img.net/img.php?mode=png&;id=20995
宜しくお願いします。
2021/05/25(火) 01:41:18.53ID:BklC19C4
その前にコード晒すなら、jsfiddleでもcodepenでも使えよ
2021/05/25(火) 06:07:46.82ID:8oRzwhWr
HTML, CSS の質問は、web制作管理板の方へ書き込んでください!

この板では、ありません
2021/05/25(火) 08:14:11.20ID:8TZ12tez
こんにちは。92歳の初学者ババアです。phpで変数のスコープをif文などの中だけにするこた出来ますでしょうか。学歴は高等女学校卒です。よろしくお願いします
116デフォルトの名無しさん
垢版 |
2021/05/25(火) 10:41:34.01ID:jhBeOJMS
>>115
僕は高卒の40歳のおっさんです。PHPで変数のスコープをif文の中だけにすることはできません。
ローカル変数のスコープは関数単位です。
2021/05/25(火) 12:16:43.78ID:8TZ12tez
>>116
ありがとうございます。
118デフォルトの名無しさん
垢版 |
2021/05/25(火) 17:29:10.58ID:i29/ofqM
どうかよろしくお願いします
https://rextester.com/ZMKMV9710
119デフォルトの名無しさん
垢版 |
2021/05/26(水) 11:02:10.68ID:2/BE6bBS
editText.cancel();
120デフォルトの名無しさん
垢版 |
2021/06/02(水) 10:43:35.98ID:qtmfAhQ7
同和ンゴ
2021/06/03(木) 22:14:14.65ID:5dXEclOp
入門未満なんですが
2進数の補数と正負の表現について分かりやすく教えてほしいです
分かりやすく載ってるサイト誘導でも有り難いです
最上位ビットが1だとマイナスを表現するとか足し算で引き算を表現するとかイマイチわからないでっす
2021/06/03(木) 22:51:11.26ID:pwK5sftK
Wikipediaの符号付数値表現の項を見たらいいんじゃないかな
2021/06/03(木) 23:29:45.24ID:jx+ISKqI
>>121
入門未満でなんでそんなことを?Cでも書こうと?
つか、Cで書いても、デバッガで変数のメモリを確認するとかでもないと
そんな知識必要にならないが…

サイトって…補数表現とかで検索して出てくる解説、どれでもいい、と思うけど
そもそも難しい話ではないので。
124デフォルトの名無しさん
垢版 |
2021/06/04(金) 10:50:17.05ID:UUHTR6cx
>>121
自分で探せ
2021/06/04(金) 18:07:07.71ID:aBiHmFjq
>>121
雑だけど
まず今のCPUは便利なんで引き算も掛け算も割り算もコマンドで実施できるけど、
H/W的な仕組みで言うと本来足し算しか出来なくて、数値の表現も+とか-とか
存在しないんよ
なので一定のビットの塊、例えばshort型ならば16birtで数値を表現する場合、
16ビットで65535って数値まで表現できるけど、人間が-数値と認識できる表現と
して最上位ビットが立っていたら-、立っていなかったら+って決めることで
-1から-32768と0から32767を表すって決めたんだいな
決め事なんでなんでって言われても困るんだけど

で、足し算しか出来ない環境でどう引き算をするかっていうと、3から5を引くと
答えは-2なわけだけど
話を簡単にするために4ビット表現で0111が7、1111が-1、符号なしだと1111で
15ってシステムで考えると
3から5を引かずに、15から3引いて1足して5を足すと数値的には5ビット分に
なるので下4ビットだけ取り出す
桁があふれたら-、あふれなかったら+の値ってなる(分からないねw)

15は1111で3を引くと1100、これは3(0011)をビット反転させるのと同じこと
この操作を補数表現といって、理屈はともかく元の数をビット反転すれば良い
15から3引いて5を足すと17(10001)ってなるけど、数値は4ビットでは15まで
しか表現できないので17から15を引くと余りが2になり余分なビットがあるので-2
あふれたビットを引く行為は16を引くことになり1多く引かなければならないので、
最初に補数に1足しておく
この補数に1足したものを2の補数というだいな

まとめると3-5が0011(3)->1100(3を補数化)+0001(2の補数にする)+0011(5)で
10010になって、下4ビットを取り出して0010、あふれた桁を最上位ビットに入れると
1010で-2になると
かえって分かりにくいか?
2021/06/05(土) 01:44:06.37ID:MUSr8GWf
最上位ビットが±を表すのを決めたわけではなく、2の補数を使うのを決めたからそうなってるだけでは
127デフォルトの名無しさん
垢版 |
2021/06/05(土) 13:53:06.28ID:L4Bl9jnp
>>121
4ビットで考ます。4ビットでは 2の4乗=16で16とおりの表現が可能です。
正の数のみ(UINT)を扱う場合は、0〜15の数値を通常 0000を数値0、0001を数値1、....
、1111を数値15 に割り当てます(以降連続する4文字の0、1は計算機上の値、それ以外は論理上
の数値)。
正と負の数(INT)を考える場合は-8〜7(-7〜7)を0000〜1111に割り当てるわけですがUINTとの
整合性をとるため0000〜0111は0〜7に割り当てます。残りの 1000〜1111を負の数に割り当てる
ことになりますが、これには1000〜1111をそれぞれ -0〜-7(絶対値)、-7〜-0(1の補数)、
-8〜-1(2の補数) に割り当てる3とおりの表現方法があります。
いずれも最上位ビットが負数を意味します。また絶対値と1の補数には-0が存在します。
1の補数は数値を符号反転(正->負、負->正)するときおのおののビットを反転(0->1、1->0)
すればよく、2の補数はおのおののビットを反転し1を加えればよい という性質があります。
人間的には絶対値表現がわかりやすのでしょうが、下記のように演算のハードウエアが簡単で
すむという理由で計算機では2の補数が用いられます(1の補数は-0の処理がやっかい)。

減算を実行する場合、計算機に限らず、減数を符号反転して被減数に加えても結果は同じです。
2の補数ではA−BをA+(Bの符号反転+1)として演算します。
計算機の中の加算器はC+D+Cary を実行するように構成されます。Caryは桁上げビットであり、
最下位ビットだけ 3ビットの加算ができるわけです。桁上げのない加算を行うときは Cary入力を0に
して演算します。減算するときはDの入力値を反転して1を加えるわけですが、反転は各ビット毎に
XORゲートで行います(減算だけなら反転ゲートでよいが加算も減算も行うので通常はXORを使う)。
1を加える処理は別の加算器を用いなくともCary入力を1にすることで達成できます。
減算を実行するためにXORゲートの追加が必要になりますが加算器に比べれば規模は1/3程度です。

注. 計算機の中の 0000〜1111の値を論理上どう考えるかは自由。0000〜1111を2進数と考え
そのまま対応する数値0〜15を割り当てる場合ばかりではない。 --->グレイコード
128デフォルトの名無しさん
垢版 |
2021/06/05(土) 14:10:54.82ID:L4Bl9jnp
>>127
間違い
(Bの符号反転+1)             --> (Bの ビット反転+1)
 減算するときはDの入力値を反転して --> 減算するときはDの入力値をビット反転して
2021/06/05(土) 20:01:57.31ID:CJl2tIqC
>>121
そうですね、例えば十進法で 3 桁しか書く場所がない変てこな状況を考えます
十進法で 3 桁しかなかったら、そういう変てこでは 000〜999 の 1000 とおりを表現できます

ここで、500 とか  600 とかは表現しなくてもいいけど、 -1, -10, -100 をこの変てこで表現したいと思ったとします

そこで、変てこでは以下のように「読み替え」することに決めました
変てこ「003」 → 3 と読み替えます
変てこ「002」 → 2 と読み替えます
変てこ「001」 → 1 と読み替えます
変てこ「000」 → 0 と読み替えます
変てこ「999」 → -1 と読み替えます
変てこ「998」 → -2 と読み替えます
変てこ「997」 → -3 と読み替えます
………
変てこ「501」 → -499 と読み替えます
変てこ「500」 → -500 と読み替えます
変てこ「499」 → 499 と読み替えます
変てこ「498」 → 498 と読み替えます

つまり、変てこでは、数字をそのまま読むという方法のほかに、変てこでの読み替え規則を勝手に決めて、この例では -500〜499 の同じく 1000 を表現することに決めた!としてもいいわけです。
これが補数表現というやつです、今日はここまで
>>121 が私のここまでの解説を理解した、と表明してくれたのなら、この続きを書きます
130デフォルトの名無しさん
垢版 |
2021/06/05(土) 21:14:55.31ID:L4Bl9jnp
127/128 だけどちょっと論理が飛躍していました。計算機で2の補数を用いるのは、INTの
加減算が入力値の正/負にかかわらずUINTと同じ加算器で演算できることが理由です。
ただし、オーバフロー(4ビットの場合、和/差が-9以下あるいは8以上になる)には注意が
必要です。
2021/06/05(土) 22:08:38.41ID:Is+ZM/MZ
昔は論理演算やらこの辺の知識は知ってて当然みたいな感じだったのに
今ではそんなことは知らないという人も多いんだな
アセンブラレベルでは桁溢れするとキャリーフラグなりボローフラグなりが立つので分かるが
何かこういう話していると遠い昔のお話みたいな感じになっちゃうなw

後、BCDも知らない人が多そうだな
2021/06/05(土) 22:17:49.83ID:Rs3b1AUs
>>121
https://www.youtube.com/watch?v=4ly0dPogeXY
133デフォルトの名無しさん
垢版 |
2021/06/05(土) 23:15:52.24ID:L4Bl9jnp
知らないから質問する。 ここはそういうスレじゃないの?
134デフォルトの名無しさん
垢版 |
2021/06/06(日) 02:23:54.33ID:68dWM5Fy
>>125-127
2進数での補数は全てのビットが0になって桁上りする数の事であってますか?
かなり噛み砕いて説明いただいたおかげで
簡単な減算は自分で出来るようになりました。ありがとうございます。

>>3から5を引かずに、15から3引いて1足して5を足すと数値的には5ビット分に
なるので下4ビットだけ取り出す
桁があふれたら-、あふれなかったら+の値ってなる(分からないねw)

ここの動きがイメージ出来ないです。取り出すというのがよくわからないです
charに+126とか入れてるのと同じ原理になるのかな?理解しときたいです。難しい…

>>129
理解できました。続きがみたいです
2021/06/06(日) 02:46:58.87ID:xlnMgrm3
>>131
BCD補正のハーフキャリーとかは、x86-64bit ≒ AMD64 では削除されちゃいましたし…
2021/06/06(日) 03:10:28.86ID:xlnMgrm3
>>134
>>129
>理解できました。続きがみたいです

ついてきてくれてありがとうございます!では続きを書きましょう。

変てこには、変てこの範囲(10進法で3桁)だけに限定されてしまいますが、その範囲なら「それなり」に動く足し算回路が装備されています

変てこで 1 + 2 を計算します。「001」は変てこの範囲内、「002」も変てこの範囲内、で、足し算を実行します。「001」+「002」 = 「003」!
変てこで 4 + 1 を計算します。「004」は変てこの範囲内、「001」も変てこの範囲内、で、足し算を実行します。「004」+「001」 = 「005」!
変てこの足し算回路はそれなりに動いているようですね!

変てこで 3 + (-1) = 3 - 1 を計算します。3 は変てこでは「003」、(-1) は変てこでは「999」、これを機械的に変てこの足し算回路に放り込むと、「003」+「999」 = 「1002」、変てこは10進法で3桁しか書けないので「002」
つまり、3 - 1 = 「003」+「999」=「002」!

変てこで 2 - 4 を計算します。2 = 「002」、 -4 = 「996」、2 - 4 = 「002」+「996」=「998」 = -2 !
変てこで -3 + 5 を計算します。-3 = 「997」、 5 = 「005」、-3 + 5 = 「997」+「005」=「002」 = 2 !
変てこで -1 - 2 を計算します。-1 = 「999」、 -2 = 「998」、-1 - 2 = 「999」+「998」=「997」 = -3 !

変てこの足し算回路にあんまり大きすぎたり小さすぎたりする数字を放り込むと答えは変になるような気はするのですけれども、
でも、それでも変てこの足し算回路は、ほとんど普通の足し算回路と同じ、というか繰り上がりを無視するけれども普通の足し算回路が使えて、
しかも負の数を放り込んでも「それなりに」動いている気がしませんか?使っているのは普通の足し算回路なのに!

続きは来週 to be continued
2021/06/06(日) 03:38:40.89ID:deO9fsXQ
2の補数ぐらい、基本情報処理資格の教科書に書いてあるだろ

初級者用の資格に、何年掛けるつもり?
2021/06/06(日) 07:06:11.74ID:hlMsLFKT
>>137
そう思うじゃん?
そもそも基本情報処理資格の教科書ってのねーんだよなぁ
あくまであれは参考書。旧2種のころからずっと。
でさ、その2の補数、すげーすげーーーー雑にざっくり書いてあるのな。
いや、数式は短く美しくってのは分かるけれどそれとはちげーよと。
どの本もクソだなぁと思ってさ。
後に基本情報はアセンブラ選択で取得して応用情報も立て続けに取ったけれど、
まぁ旧2種の時に取らないで正解だったなとは思うよ。今ではいい参考書とインターネットがあるからね。
2021/06/06(日) 07:19:24.55ID:bpZDov45
どこまで詳しく書けばクソじゃなくなるのかね
2021/06/06(日) 09:50:55.63ID:Bm4Wg/Px
負数を2の補数で表現するメリットは、符号付き整数と符号無し整数の加算が同じ方法で実現できることにある
例えば4ビットなら 8〜15 を -8〜-1 に置き換えるだけ

符号無し整数の加算表
http://imgur.com/c5HXPen.png

符号付き整数の加算表
http://imgur.com/Wl7u3Fv.png
141デフォルトの名無しさん
垢版 |
2021/06/06(日) 10:47:51.39ID:9mmqAG88
>>125
そんな判りにくい説明せんでも
3-5 を説明するのに 10進数を1桁で考えたときに
0,1,2,3,4,5,6,7,8,9 (A) を
0,1,2,3,4,-5,-4,-3,-2,-1 (B) に割り当てて
3-5 (B) は 3+(-5) (B) だが
-5 (B) の部分を順序だけ考えて 5 (A)
つまり 3+5=8 (A) に還元出来るので
出て来た 8 (A) をさらに実は -2 (B) であると読み取ってるだけだよ
2進数の引き算でも本質はこれ
2021/06/06(日) 14:04:14.80ID:deO9fsXQ
これだけでしょ?

1の補数は、全ビット反転
2の補数 = 1の補数 + 1

クイズ、資格に出そうな問題です

8進数の634 は、16進数で幾つか?
どのように考えて解いたかも、示せ
2021/06/06(日) 16:14:14.11ID:EZGLOGww
110,011,100
1,1001,1100
符号拡張無しなら 19c
符号拡張有りなら f9c
2021/06/06(日) 16:37:00.44ID:yq1OPwe7
今時はCPUの設計も自動化されているので
2の補数を使うのはCPUの自動設計のプログラムを
書く人ぐらいだなあ
145デフォルトの名無しさん
垢版 |
2021/06/06(日) 21:57:17.31ID:LwUdRMIi
>>134
> 2進数での補数は全てのビットが0になって桁上りする数の事であってますか?

元の数と足して桁上りするという意味で2の補数ではあってます。
Wikiの次の定義が一番すっきりすると思います。
< b 進法において、自然数 a を表現するのに必要な最小の桁数を n としたとき、
< (bのn乗) − a :「b 進法における a に対する基数の補数(b の補数)」
< (bのn乗) − a − 1 :「b 進法における a に対する減基数の補数(b - 1 の補数)」

蛇足ですが、4ビットの場合で各ビットを b3,b2,b1,b0 としたとき、UINT は
 論理上の数値 = b0×1 + b1×2 + b2×4 + b3×8
です。2の補数は 最上位ビットに負の重みを与え
論理上の数値 = b0×1 + b1×2 + b2×4 + b3×(-8)
と考えます。b0+NOT b0 = 1 ですから 元の数とそのおのおののビットを反転した値を
足して1を加えれば 0 なることがわかります。
UINTでも2の補数も下位3ビットは同じです。なので下位3ビットは同じ方法で演算ができます。
2の補数では最上位ビットが符号ビットです。 正+正 / 正+負 / 負+負 の加算でそれぞれ
3ビット目からの桁上がりがない場合とある場合の計6とおりを考えれば(オーバフローが
ない限り)UINTの加算と同じ結果になることが確認できます。
146142
垢版 |
2021/06/07(月) 12:31:33.61ID:pl6618+T
>>142
8進数 → 16進数は、
8進数 → 2進数 → 16進数と、一旦2進数へ変換してから、16進数へ変換する

0o634 → 110_011_100
これは区切り方を変えて、1_1001_1100 と同じ。つまり、0x19c
2021/06/07(月) 13:28:49.75ID:KkC2AFNL
>>134
>>125はあちこち微妙だけど
>3から5を引かずに、15から3引いて1足して5を足すと数値的には5ビット分になるので下4ビットだけ取り出す桁があふれたら-、あふれなかったら+の値ってなる(分からないねw)
の最後のところ、分からないといっている4ビット取り出して桁あふれ云々ってところは完全に間違っている
3-5のところで10010になるところまではまぁ間違っていないけど、説明の通り下4ビット取り出して、その後の説明の通り5ビット目の内容を入れた1010は4ビットで表される-2(1110)ではない

最後の部分は桁あふれ云々じゃなくて、出てきた値から単純にもう一度2進数の補数を作ればちゃんとした値になる
10010->1101(NOTを使って1の補数化)->1110(1追加して2の補数化)

同じ理屈で5-3をやってみればわかるけど、>>125の説明の通りやると出てくる値は1110で-2になってしまうので、ぱっと見-取ればあっているような気もするけど計算ではうまく言っていない

最後を2の補数処理にすれば1110->0001->0010で正しく4ビットで表す2になる
148142
垢版 |
2021/06/08(火) 09:48:04.68ID:dOMi6vvz
1の補数は、全ビット反転
2の補数 = 1の補数 + 1

1の補数では、0〜3が、-0〜-3 になる。
0: 000、-0: 111

0・-0の2つがあって、ややこしい。
だから、負側を1下げた。
0〜3が、-1〜-4 になる。

2の補数 = 1の補数 + 1

3: 011、全ビット反転・-4: 100、それに1を足す・-3: 101。
011 + 101 = 000
3 + -3 = 0

3 + -4 = -1
だから、1を足さないと、0にならない
2021/06/08(火) 17:11:48.32ID:8abk1CkH
 2進数で盛り上がってますね。
 私も当時(中高生時代)とても苦労したなあ。
 ただの加算減算なら指定数のビット幅を任意に揃えれば良いだけだったけど、補数演算じゃ最上位ビットを決めなければいけないのにその指定が指示されなくてサッパリだった。
 今なら空気読んで指定数に干渉しない位置で補数ビット指定できるけれど、当時出来なかった。学習障害案件ですな(^^;

 今の時代、まず2進数を扱う事って無くなったけど、知っていると圧倒的にコンパクトで快速データ構造が作れるから、やっぱ必須ですね。
2021/06/08(火) 18:03:26.50ID:rroj7r75
・なんで補数を使うか
・なんで1の補数でなく2の補数なのか
この2つに答えられれば理解できているだろう
2021/06/09(水) 16:09:11.53ID:Gt06K9sH
馬鹿が説明すると余計判りにくくなる
2021/06/10(木) 22:40:22.57ID:CSATwpX+
>>149, 150
私は、補数概念は 2 進法以外であっても説明できなければならないと思うようになりました >>129,136
2021/06/12(土) 17:12:07.12ID:XQCPcV2p
減算はマイナス値の加算である。マイナス値は正の値の補数で表現する。ただそれだけ。
2021/06/12(土) 18:33:32.77ID:bLldo3g7
プログラミング超初心者の質問スレとはなんだろうか
2021/06/12(土) 19:23:38.54ID:TNpjfLIA
超初心者の質問に
優しく丁寧に教える趣旨のスレではない
2021/06/12(土) 20:05:09.18ID:bG62sF4n
>>153
で、補数とはなんですか?それは n 進法に依存する概念ですか、それとも n 進法とは独立した概念ですか?
2021/06/18(金) 00:55:46.99ID:rMpkljNE
>>156
結局整数で考える限りは2進数に変換できる。
なので、どんな整数についても、2の補数も1の補数もある。
n進法は単に数値の表記の問題でしかないので、
そこに依存する「概念」ってのがそもそもないだろう。
2021/07/04(日) 20:08:20.69ID:DFBUOLaH
C++の入門本に載ってるようなコンソールに表示させるコードは覚えたから
簡単なアプリ作ってみたいのですが、"C++ アプリ"でググっても
ツールボックスで貼って作っていくようなやつや専門学校の案内しか出てこないのですが(やりたいのはこれじゃない…)
C++で1からアプリを作れるようになるにはWin32APIというのを覚えなくてはいけないのでしょうか?
2021/07/04(日) 20:30:07.06ID:Y0mUgNX8
どういう種類の「アプリ」を作りたいのかはっきりしてくれ
2021/07/04(日) 20:47:59.93ID:DFBUOLaH
Guiアプリ内で、ただ球が跳ねてるのとかヘビが動いてるのとか作りたいです
最終的にはhttps://www.youtube.com/watch?v=wlmQKjm0dSoみたいのを作りたいです
2021/07/04(日) 21:08:09.77ID:aHJdtdht
ゲームは、C# でUnity とか、
JavaScript でPhaser とか

C++ はツール・ライブラリ用。
画面を作ったりはしない

Linux では、Qt はあるけど、
Windows では、C# になる
2021/07/04(日) 21:28:17.94ID:DFBUOLaH
>>161
https://www.youtube.com/watch?v=LrEvoKI07Ww&;t=507s
でもC++で作ってる動画たくさんあるので出来る事はできるのではないですか?
できればC++で作れるようになりたいのですが。
せっかく少し文法覚えたので。
2021/07/04(日) 21:33:19.84ID:hQ73PqG+
結局はC#で用意されてるようなものを
自前で作るだけって話だろ
2021/07/04(日) 22:49:46.61ID:DFBUOLaH
最終的な目標はC++でアプリ、簡単なゲーム作れるようになることなんですが
C#を今から始めてC#の方で色々作れるようになったらその知識はC++で生きますか?
165161
垢版 |
2021/07/04(日) 22:54:42.87ID:aHJdtdht
>>162
それは、7年前の動画じゃん

ここ数年で、C++ で画面を作るような本が出たか?
2021/07/04(日) 22:59:36.21ID:cArVphVF
C++なら何でもいいなら
ラズパイとかでもええんかいな
2021/07/04(日) 22:59:50.06ID:GIk3CAEY
とりあえずID:aHJdtdhtは頭のおかしい人だから無視していいよ
2021/07/05(月) 02:35:32.08ID:k33LLnq0
C#やるしかない、が回答でしょうか?
2021/07/05(月) 03:26:10.42ID:MF6GczCZ
>>157
それって変だと思いますよ
>>129, >>136 では 10 進法で考えましたが、じゃあ >>129,136 の例の 999 は -1 に対する補数ではありますが、1 の補数ともいえないし 2 の補数ともいえない
補数の概念は n 進法に依存するのでは?

もっとも今の私はちゃんと説明するなら整数論の合同、を使って説明する気がしますが、ただ、整数論なんて好きな人は限られますからねえ‥‥
2021/07/05(月) 08:41:07.01ID:yW7vm9zn
10の補数だな
知らないことを責めはしないが
自分で調べる位はせんと
171158
垢版 |
2021/07/05(月) 11:06:36.25ID:4P9s6hFJ
すいません
http:ああwisdom.sakura.ne.jpあsystemあwinapiあwin32あindex.html
これを学習しても>>158 >>160のようなことは出来るようにならないですか?
172デフォルトの名無しさん
垢版 |
2021/07/05(月) 11:14:40.55ID:c503ASju
>>158
君のレベルならこれ
ISBN 4899774451
ISBN 4899775067
あるいは
https://nono-programming.com/dx-library/
https://dxlib.xsrv.jp/use/dxuse_vscom2019.html
https://dixq.net/g/
173デフォルトの名無しさん
垢版 |
2021/07/05(月) 11:19:04.61ID:c503ASju
>>161
KENTA Ruby はしね
2021/07/05(月) 11:22:39.85ID:sSIakhI1
129は1000の補数じゃないかな
175デフォルトの名無しさん
垢版 |
2021/07/05(月) 11:26:29.03ID:c503ASju
>>169
お前も黙ってろ
2021/07/05(月) 11:59:03.74ID:DJ8mSFAE
>>160
C++ ゲーム ライブラリ
でググればいくらでも出てくるが
DirectX, penGL/Vulkan, DXライブラリ、OpenSiv3D, SFML, openFrameworks,SDL
どれでもお好みのものを使ってね
2021/07/06(火) 20:22:57.18ID:/lKUoH39
>>170
知ってていってるんですよ、そんなこともわからないのですか?
私がいいたいことは、補数概念は n 進法と密接に関連あるのでは?ということ
2021/07/06(火) 20:23:13.71ID:/lKUoH39
>>175
やだね
2021/07/06(火) 23:48:06.12ID:xK9Ol7Aw
>>177
そんなことも知らんのか
180デフォルトの名無しさん
垢版 |
2021/07/07(水) 16:58:01.30ID:z+//4KUJ
超初学者です。現状は、独学プログラマーという入門書を読み終えてPythonのプログラムを関数を調べながらですが何となく読めるようになりました
しかし何かを作ろうとしても全く手を動かせません

疑問なのですが
ループ処理とクラス、関数は同じ事をするという点で同じだと思うのですがどういう時のどういう場合にどういった考え方で使うのか教えて頂きたいです
それぞれの使い分けというかそれぞれの使い方を教えて下さい
また、次に読む本についてhttps://i.imgur.com/dPPUpMq.jpgこちらはどうですか?
2021/07/07(水) 18:18:07.45ID:AWE9BvFy
仕事しててクラス、関数、ループとかに慣れたいなら作業をVBAで出来ないかとかやってみればいいわ
古いくさい言語だけどそこら辺は実装されてるし、何よりVBEって言うIDEしか選択肢ないから環境に悩まない

他には、まずやりたいこと探した方がいいよ
モチベ続かんやろ
簡単なとこなら、適当に無料のWeb API(天気予報とか)見つけて表示したりファイルにしてみるとか
ちょっと頑張って、立てたサーバからそのデータをLINEに通知してみるとか、興味あるものこそがモチベになる
2021/07/07(水) 19:37:52.26ID:vV9ueWFY
文字列処理の練習しろ
文字列処理はすべての基本だ
2021/07/07(水) 21:15:08.84ID:bUHYGk47
Ruby で、ファイル操作・テキスト処理をやる。
each, map など、繰り返し(Enumerable)の所を読む

例えば、a.csv と言う、以下のようなCSV ファイルの、1列目を出力すると、
あ,いう
a,bc

require 'csv'

# CSV ファイルを、1行ずつ処理する
CSV.foreach( "a.csv" ) do | row |
puts row[ 0 ]
end

出力

a
184デフォルトの名無しさん
垢版 |
2021/07/08(木) 10:53:53.10ID:nEG9xKCJ
N!進数(階乗進数)の補数について語ってください
2021/07/08(木) 18:24:58.17ID:k+qVnEjt
>>180
疑問部分だけ
例えば「X=1/2*A*H」という式に「H」を計算する部分がある10行くらいの
コードがあって、「A」が2、4、6、8・・・という感じで値が定期的に変異する
場合には、対象となる10行くらいのコードをループで囲めばループ処理になる

でも、「A」が2、5、7、13、14というようにパターンのない変異の場合、計算式と
なる処理に変更はなくても、値をループでは変異させられないので「A」の値を
設定して10行の処理を書いてということを繰り返すしかなくなる

この同じ処理である10行を一つにまとめて呼び出せるようにしたのが関数
関数化していない状態で10回値が変異するコードを書くと110行とかかかっちゃう
けど、関数化していれば20行+10行+アルファですむ

なのでループ処理と関数は全然違うもの

さらにクラスは処理を行うための仕組みではなく、データ等の構造を定義するための
ものなのでループ処理とか関数とは全然関係ない別の概念

例えばさっきの式は三角形の面積を求める式だけど、三角形のクラス「Triange」を
作るとき、A(底辺)とH(高さ)とX(解)というプロパティを宣言して、Xの値を呼び出す
ときは計算結果を入れて返すってなっている場合定義したクラスのインスタンスを
取得して、AとBに値を入れてCを読み込むと計算結果が得られる

クラスはこの構造を定義するためのもので、当然のごとく処理も記述されるけど、
目的は一連の関係性のあるパラメータや関数(クラスではメソッドとか呼ぶ)を
まとめること

サンプルの簡単なコードとかだと違いがないように見えるのかもしれないけど、
アルゴリズムとかデータ構造とか勉強してからもう一度コードを見ると理解
できるかも
2021/07/08(木) 23:24:27.32ID:f1qLfxS8
むしろ
>ループ処理とクラス、関数は同じ事をするという点で同じだと思うのですが
と思った理由を知りたいわ
187デフォルトの名無しさん
垢版 |
2021/07/09(金) 02:26:58.85ID:pOJ0VHTV
>>181
モチベについてよく分かります
現在は色々と目新しいので、へぇこういうの出来るんだーという面白さが学習の意欲を保っているのですが
学習を始めた理由はクラウドサービスにある例えばデータ収集等のバイトを受けたいからになります

レスありがとうございます!
ちょっと背伸びになるんですが調べながらその2つ取り掛かってみます
188デフォルトの名無しさん
垢版 |
2021/07/09(金) 02:48:42.58ID:pOJ0VHTV
>>185
ご丁寧にありがとうございます!マジで助かります

クラスについて大変しっくりきました色々と作りながら扱い方を深めていこうと思います
自分は超初学者でして素っ頓狂な質問であれば失礼で申し訳ないのですが、色々と見ているとループ処理自体が特別な関数であるかのような感じ方をしてしまうのですが間違ってますか?
また、ループ処理はどんな発想で入れようと思うのですか?
189デフォルトの名無しさん
垢版 |
2021/07/09(金) 03:09:34.30ID:pOJ0VHTV
>>183
ありがとうございます!
Rubyのリファレンスマニュアルを覗きましたが勉強不足でRubyが分からず正直何が何だか分かりませんでした。ブックマークしまして分かりそうな頃に参照します
他の言語であれば繰り返しにも種類があるという事ですか?
190デフォルトの名無しさん
垢版 |
2021/07/09(金) 03:13:09.62ID:pOJ0VHTV
>>187
ごめんなさい
クラウドサービスではなく、クラウドソーシングサービスと誤りました
2021/07/09(金) 08:42:59.13ID:Q5IOaLlz
>>188
ある条件で操作を繰り返したいときがループ

古典的なfor文では、例えば1から100までひとつづつ
100回繰り返したい時にループを使う

while文ではある条件が満たされている間処理を繰り返す
192デフォルトの名無しさん
垢版 |
2021/07/09(金) 14:38:41.37ID:pOJ0VHTV
>>191
例えばですが、>>185の三角形の面積の例であれば代入する値が決まっていればforの中に入れても結果は変わらないですが、ループ処理とはもっと複雑になった時に何が便利なんですか?
193デフォルトの名無しさん
垢版 |
2021/07/09(金) 15:02:26.10ID:pOJ0VHTV
>>192
あとある値を起点に何かの処理を2回したい場合の話ですが、例えばループ処理を通した値をリストで出力していて後からその出力のある値を使いたい場合に

初めにループに入れたある値のインデックス値が分かっていれば、インデックス値を参照して出力された方のリストから値を取り出して関数というか引数にいれたりして結果に導くといったことが出来そうというのは間違ってますか?
この場合、関数の戻り値を関数に入れるのが良いのは分かりますがお答え頂けると嬉しいです
2021/07/09(金) 15:24:32.13ID:zwat9LTE
難しく考えすぎでは

例えば配列の内容をすべて足し算したいときに
内容を一個ずつ取り出してどんどん足していく
こういう時にループが有効

文字列の配列があったとして
その中に特定の文字列が含まれているものを抽出したいときに
ループで配列を一個ずつ見ていく

まずはこんなところでは?
195183
垢版 |
2021/07/09(金) 21:26:29.08ID:TIX9j1Dy
>>189
Ruby・module Enumerable
https://docs.ruby-lang.org/ja/latest/class/Enumerable.html

繰り返しを使って、どういう処理が出来るか?
これが全言語に共通している部分・デザインパターン

JavaScript のLo-dash などと同じ

ここを読んでおくと、
確か、こういう処理・デザインパターンは書いてあったとか、思い出せる

例えば、複数の配列(繰り返しオブジェクト)を同時に繰り返す、zip とか

p (1..3).zip([4,5,6], [7,8,9])
# => [[1, 4, 7], [2, 5, 8], [3, 6, 9]]

こういうデザインパターンを覚える。
つまり、自分で作らない。車輪の再発明をしない
196デフォルトの名無しさん
垢版 |
2021/07/10(土) 01:21:57.95ID:UexQQhng
>>195
Rubyの記号やPythonより書いてる事が多く、やっとPythonが少し分かるようになったばかりの自分には結構読むのが苦しいんですが何となく一読しました

車輪の再発明をしないってのをよく覚えておきます。
RubyのEnumerableモジュールのメソッドについて参考にするのが良いと知れて良かったです

https://qiita.com/yohm/items/18b1f206267c31f4da72
197デフォルトの名無しさん
垢版 |
2021/07/10(土) 01:27:10.08ID:UexQQhng
こちらで質問をしなければ、知り得なかったと思うので大変助かります
本当にありがとうございます!

Pythonだとどうなるかまとめられた記事がありました
2021/07/10(土) 10:39:19.80ID:qdrVIv6G
pythonの勉強をしてます。
コマンドプロンプトからファイルを実行しようとするとVScodeが起動してファイルを開くようになってしまい、実行した結果を確認できなくなってしまいました。
治す方法教えてください。

以前
C:/Users/aki/Desktop/pythonrensyu/r2nen/test.pyをコマンドプロンプトに入れると
hellow worldと表示される


C:/Users/aki/Desktop/pythonrensyu/r2nen/test.pyをコマンドプロンプトに入れるとVScodeが開き、test.pyの編集画面が出る

以前に戻したいです
2021/07/10(土) 13:32:42.21ID:r0cN22jq
>>198
test.py の中身をここに書き込んでみてください
200デフォルトの名無しさん
垢版 |
2021/07/10(土) 14:22:45.22ID:1RIzGkFx
>>199
中身は関係ないだろ・・・
201デフォルトの名無しさん
垢版 |
2021/07/10(土) 14:23:40.60ID:1RIzGkFx
関連付けを変えれば良いだろうけれどもWindowsの関連付けは複雑だからなあ
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

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