C言語なら俺に聞け( ..
[2ch|▼Menu]
892:デフォルトの名無しさん
09/10/27 15:56:14
>>887
printf("トリップキーを入力:");
scanf("%u", &tripkey);

printf("トリップキー入力"); ←これが表示されずにコアを吐く
fflush(stdout); ←これを追加したら↑これ出ないかな

893:デフォルトの名無しさん
09/10/27 16:33:35
>891
本来ならそんな感じで呼び出すはずだけど

僕の環境では
/usr/include/unistd.h:1073:extern char *crypt (__const char *__key, __const char *__salt)
/usr/lib/i386-redhat-linux4E/include/unistd.h:1019:extern char *crypt (__const char *__key, __const char *__salt)
となっていたから

diff
96c96
< *trip_f = crypt(*tripkey, *salt);
---
> strcpy(trip_f, crypt(tripkey, salt));

結果
./up1812
トリップキーを入力:foo
トリップキー入力トリップキー前処理salt作成1回目:OK2回目:OK3回目:OK4回目:OK5回目:OK◆yaoo

894:デフォルトの名無しさん
09/10/27 20:59:52
typedef struct data{
___char mozi[100]; //文字列格納用
_______int year[100];//点数格納用
}Data;

Data data[100];構造体を100個用意

data[0].mozi="aaaaaaaa";←*1

printf("%s",data[0].mozi);

これでコンパイルすると*1の部分が「左辺値が必要」といわれてしまいます。
どうやったら文字列を格納できるのでしょうか?

895:デフォルトの名無しさん
09/10/27 21:10:43
strcpy

896:デフォルトの名無しさん
09/10/27 21:12:36
strcpy(data[0].mozi,"aaaaaaaa");

897:デフォルトの名無しさん
09/10/27 21:14:53
>>895-896
ありがとうございます。
配列=配列ができないのと同じ原理なんですね。

898:デフォルトの名無しさん
09/10/27 22:46:47
char *a[8];
char (*b)[8];

この違いを教えてください。

899:デフォルトの名無しさん
09/10/27 22:47:50
Cってカンタンだよね。
すぐにUSB接続デバイスとか
作れそう。

900:デフォルトの名無しさん
09/10/27 22:54:26
>>899
DDK次第

901:デフォルトの名無しさん
09/10/27 22:55:55
道路の交通量調査などに使われてる(?)紅白で野鳥の会の人が使ってる(?)
カウンターの様な機械をC言語で作ってみたいと思っています。

コマンドプロンプト上で、Enterを押せば数字が増えていくというモノです。

Enterの入力があれば用意した変数に1を足して出力 とするプログラムはすぐに書けると思うのですが、
C:\>counter.exe
Enterの入力回数:1
Enterの入力回数:2
Enterの入力回数:3
・・・・
Enterの入力回数:100
の様な感じになると思います。
C:\>counter.exe
Enterの入力回数:XXX として、Enterを押せばXXXの部分の数字だけを書き換える
という事は出来るのでしょうか?

説明が下手なのですが、内容を察して教えて下さい。
もしよろしければコーディングまでよろしくお願いします。

902:デフォルトの名無しさん
09/10/27 22:58:31
CLSして再描画する?

903:デフォルトの名無しさん
09/10/27 23:03:20
#include <stdio.h>
int main(void)
{
  int counter=0;
  while(1){
    int c = getchar();
    if(c=='\n'){
      counter++;
    }
    system("clear");
    printf("counter:%d\n", counter);
  }
  return 0;
}

※windowsならsystem("cls");

904:デフォルトの名無しさん
09/10/27 23:05:15
>>901
非標準な事をすれば可能
環境を書いてくれないと無理

905:デフォルトの名無しさん
09/10/27 23:11:20
>>901 conio.h があるなら
#include<stdio.h>
#include<conio.h>

#define KEY_ENTER 0x0d
#define KEY_ESCAPE 0x1b

int main(void){
int count=0, key;

while(1){
key=getch();
if(key==KEY_ENTER) printf("\rEnterの入力回数:%d ", ++count);
if(key==KEY_ESCAPE) break;
}
return 0;
}

906:デフォルトの名無しさん
09/10/27 23:11:30
>>901
本当はこうなってるんじゃないの?

C:\>counter.exe

Enterの入力回数:1
Enterの入力回数:2
Enterの入力回数:3
・・・・
Enterの入力回数:100

表示が本当に >>901 の通りなら入力にエコーが無いから
単に改行しなければ良いだけだろ


907:デフォルトの名無しさん
09/10/27 23:12:57
int counter=0;

これってCだと必須なんだ。
変数を宣言しないと
つかえないから。

908:894
09/10/27 23:17:53
/**おまじない省略**/
struct suji{
char moji[100];//文字列格納
int su[100];//数字格納用
};

int main(void)
{
____struct suji score[100];//100の構造体を用意
____FILE *fp;
____char *tp;
____char str[256];//ファイルの行を格納する配列
____int i=0,k=0;

____ if((fp= fopen("input.txt", "r")) == NULL)exit(1);
____________while( fgets(str,256,fp) != NULL)//ファイルの中身がなくなるまで
____________{;
/************文字列格納******************************/
________________tp=strtok(str,","); //文字列格納 tp=ポインタ
________________strcpy(score[i].moji , tp); //文字列コピー
________________printf("%s\n" , score[i].moji); //テスト表示
________________i++;//構造体を一つ進める
/***************数字格納******************************/
____________________while(tp!=NULL){//一行読みきるまで
____________________________score[i-1].su[k] = atoi(strtok(NULL , "," ));//i-1は上でi++してるため無効化する作業
____________________________printf("%d\n" , score[i-1].su[k] ); //テスト表示
____________________________k++;
____________________}
_____________}
___________fclose(fp);
___________return 0;
}

909:894
09/10/27 23:18:57
上のプログラムはCSVファイルを一行ごとに構造体配列に格納するプログラムを目指してます。
input.txtには、文字列,数字1,数字2・・・,数字n(文字列は行の先頭に一つだが、数字はいくつでも可能)といった形式で入っています。

このプログラム、コンパイルは正常にできますが実行するとエラーで強制終了となります。
何がおかしいかご教授ください。

CSVファイルが
aiueo,10,23,53,55,60
kakikukeko,22,33 
の2行だったら格納後、適当なメンバを参照すると
score[0].enzan=aiueo
score[0].su[0]=1
score[0].su[1]=2
score[1].enzan=kakikukeko
score[1].su[1]=33
という具合になる予定です。



910:デフォルトの名無しさん
09/10/27 23:20:25
score[0].su[0]=10
score[0].su[1]=23
の間違いです。

911:デフォルトの名無しさん
09/10/27 23:23:32
>>898
全然違う。後者に使い道はない。

912:デフォルトの名無しさん
09/10/27 23:28:16
今、大学の課題を考え中なのですが、
「定義域 -1.5<=x<=1.5の時
 関数 y=3x^3-0.2x^2+0.3x-0.7
 の値を出力するプログラムを作れ。
 なお、xは-1.5から0.1刻みで増やすこと」

という問題なのですが、
↓のようなプログラムを実行させると
なぜか、x=1.5のときだけ出力されません・・・


913:つづき
09/10/27 23:28:59
#include <stdio.h>

main()
{
float x, y, step;
x=-1.5;
step=0.1;
y=0.0;

while(x>=-1.5 && x<=1.5){
y=3.0*x*x*x-0.2*x*x+0.3*x-0.7;
printf("%4.1f %9.5f\n", x, y);
x = x + step;
}


}

ちなみに、
whileの中の条件式を
x>=-1.5 && x<1.6 (右の不等式のイコールをとって、1.6にしてみた)
とか
x>=-1.5 && x<=1.51
とかにかえると正しい結果が得られました。

どこで間違ってるのでしょう??

どなたかご教授願います
m(_ _)m


914:デフォルトの名無しさん
09/10/27 23:40:45
>>911
使い道はある
(単純な二次元配列でも使うし固定長配列へのポインタを関数の引数にする場合にも使う)

>>898
>char *a[8];
char *a; が8個
char *a[8] = {"abcd", "ef", "gh", "ijkl", "mnopq", "rst", "uv", "wxyz"};

>char (*b)[8];
char [8]へのポインタb または char [8]がn個 の配列
char (*b)[8] = {"abcdefg", "1234567", "zyxwvut"};


915:デフォルトの名無しさん
09/10/27 23:41:31
浮動少数は厳密なものじゃなく近似値だから
ピッタリでは判定できないことが多いよ。


916:デフォルトの名無しさん
09/10/27 23:46:56
while(!((x+1.5)<0.0 || (x-1.5)>0.0)){


917:デフォルトの名無しさん
09/10/27 23:49:58
>>913
0.1を正確に表せないから。

step=0.1;
としても、0.1よりちょっとずれた値になるので、何度も足してると誤差が蓄積する。
誤差少なくするなら、
double x;
int n;
for(n = 0; n <= 30; n++){
x = -1.5 + n*0.1;
...
}
みたいな。

918:デフォルトの名無しさん
09/10/28 00:16:08
>>917

へぇ〜
そんな話、聞いたことありませんでした!!
ありがとうございました!!

ところで、
どうして、その1次関数で
誤差を少なくすることができるのでしょうか??

何度も何度も聞いてしまってスイマセン・・・
m(_ _)m

919:デフォルトの名無しさん
09/10/28 00:27:33
>898

型が違う。

aはcharを指すポインタの配列(要素数は8)
bはcharの配列(要素数8)を指すポインタ

aに+1するとsizeof(char*)増加(32ビット環境なら通常4)
bに+1するとsizeof(char[8])増加(8)


920:デフォルトの名無しさん
09/10/28 00:30:01
>897

>配列=配列ができないのと同じ原理なんですね。
というか、文字列リテラル("aaaaaaaa")の型はconst charの配列
なので、問題の箇所は「配列=配列」そのもの。

921:デフォルトの名無しさん
09/10/28 00:35:35
>911

>>898
>全然違う。後者に使い道はない。


いやいや、普通にあるでしょ。
char a[N][8];
を引数にとる関数の仮引数の型がそう。



922:デフォルトの名無しさん
09/10/28 01:10:00
ならなんで
char *(b[8]);
じゃないの?

923:デフォルトの名無しさん
09/10/28 01:28:14
fclose() が NULL を受け付けないおかげで
fclose(func(fopen(fname,"r")));
みたいに出来ないから困る。
free(func(malloc(s)));
ならできるのにな。


924:デフォルトの名無しさん
09/10/28 01:36:53
char (*b)[8];について、
演算子の優先順位で覚えればいいと言いたい所だけど、
*は、演算子では無くポインタ宣言子なわけで、
(ついでに言うと、[]もここでは演算子でないのよ、優先順位は、高 () > [] > * 低)
でも、間接参照するときは、(*b)[i]のようにしないと演算子の優先順位があって、
いや、何というかね

char *(b[8]);は、bに[]が付いているから、bは配列、それに*が付いているから、ポインタの、型はcharである。
つまり、bは、char型のポインタの配列と解釈されるわけで。b is array[8] of pointer to char.優先順位の高い方から低い方へ。
まぁ、『Cの強化書』とか『エキスパートCプログラミング』でも読めばいいよ。

925:デフォルトの名無しさん
09/10/28 01:43:12
NULLを受け付けるようなfcloseを自分で作るとか一瞬だけ思ったんだが駄目かな

int myfclose(FILE *stream)
{
 if(NULL == stream)
  return 0;
 else
  return fclose( stream );
}

926:デフォルトの名無しさん
09/10/28 01:47:22
素直にwrapper作ればよくないか
標準関数を直呼びすることはあまり無くなった
int safe_fclose(FILE *f) {
 if ( f == NULL ) {
  return 1;
 }
 return fclose(f);
}
戻り値を何にするかちょっと悩んだ。

927:デフォルトの名無しさん
09/10/28 01:57:14
#include <stdio.h>
#include <time.h>
#include <Windows.h>
int main(void){
time_t timer;
struct tm *t_st;
while(1){
time(&timer);
printf("現在時刻: %.24s\r", ctime(&timer));
Sleep(1000);
}
}
このプログラムで、Ctrl+Cの強制終了ではなく、Escapeなどできれいにプログラムを終了させるには
どうしたら良いでしょうか?

928:デフォルトの名無しさん
09/10/28 01:59:43
>char *(b[8]);は、bに[]が付いているから、bは配列、それに*が付いているから、ポインタの、型はcharである。

doubt

929:デフォルトの名無しさん
09/10/28 02:01:57
windowsみたいだから
getchでESC押されたか判定して抜けると良いんじゃない

930:デフォルトの名無しさん
09/10/28 02:03:00
>>927
escapeがきれいだとは思わない

931:デフォルトの名無しさん
09/10/28 02:04:04
どうしてそんなにsleepしたがるのだ。
OSに大麻イベントをセットしてWM_TIMERで読んでもらえばいいじゃないか。
え?ミリ秒単位で制御したいの?

どっかのスレで誰かが副作用で暴れてたなぁ。

932:デフォルトの名無しさん
09/10/28 02:13:11
>>927
#include <stdio.h>
#include <time.h>
#include <Windows.h>
#include <conio.h>

int main(void){
time_t timer;
struct tm *t_st;
while(1){
time(&timer);
printf("現在時刻: %.24s\r", ctime(&timer));
Sleep(1000);
while(kbhit()){
if(getch()==0x1b)break;
}
}
}


933:デフォルトの名無しさん
09/10/28 02:14:19
ごめん間違えた。

934:927
09/10/28 02:17:14
>>929
#define KEY_ESCAPE 0x1b
int key;
while()1{
key=getch();
if(key==KEY_ESCAPE) break;
・・・・・
}
としてみたのですが、何かキーを押さないと時刻を更新しなくなります。

>>930
そうですよね。


強制終了ではなく、キー入力でwhileから抜けて処理終了を「きれい」と言っていました。

>>931
全く知識がないので、sleep使えば手っ取り早くできるかなと思いまして・・・・

935:デフォルトの名無しさん
09/10/28 02:19:18
#include <stdio.h>
#include <time.h>
#include <Windows.h>
int main(void){
time_t timer;
struct tm *t_st;
while(1){
while(!_kbhit()){
time(&timer);
printf("現在時刻: %.24s\r", ctime(&timer));
Sleep(1000);
}
if(_getch()==0x1b)break;
}
}


936:デフォルトの名無しさん
09/10/28 02:23:55
エレガントじゃないな。

#include <stdio.h>
#include <time.h>
#include <Windows.h>
#include <conio.h>
int main(void){
time_t timer;
struct tm *t_st;
do{
while(!_kbhit()){
time(&timer);
printf("現在時刻: %.24s\r", ctime(&timer));
Sleep(1000);
}
}while(_getch()!=0x1b);
return 0;
}

こうだろ。

937:927
09/10/28 02:37:30
kbhit()なんてものがあったんですね。

もしお時間があれば、>>931さんの言うタイマーイベントを使ったプログラムのサンプルをお願いします。

私の環境はWinVista
コンパイラ:Borland C++ 5.5.1
です。

よろしくお願いします。

938:デフォルトの名無しさん
09/10/28 02:43:07
ボーランドのコンパイラなら

_kbhit() → kbhit()
_getch() → getch()

に置き換えだな。
MicroSoft は非標準には '_' を付けてる。

939:デフォルトの名無しさん
09/10/28 02:44:59
Windows のタイマーイベントはウィンドウメッセージだから、
それを受け取るウィンドウが必要だぞ。

940:デフォルトの名無しさん
09/10/28 02:48:35
つ select

941:デフォルトの名無しさん
09/10/28 02:49:22
宿題スレでもC++対応でそこに誘導している以上
このスレもC++拒否じゃなくて、無保証対応で
良くね?

942:デフォルトの名無しさん
09/10/28 03:09:06
>>937
#include <stdio.h>
#include <time.h>
#include <Windows.h>

VOID CALLBACK tp(HWND hwnd, UINT u, UINT_PTR p, DWORD dw){
time_t timer;
struct tm *t_st;
time(&timer);
printf("現在時刻: %.24s\r", ctime(&timer));
}

int main(void){
SetTimer(0,0,1000,tp);
while(getch()!=0x1b);
return 0;
}


943:デフォルトの名無しさん
09/10/28 04:53:52
>>924
その本には char (*b)[8]がポインタの配列であると書いてるの?
そうなら子供の落書き帳にでもしちゃいなよ

944:デフォルトの名無しさん
09/10/28 04:55:35
うあ?
途中から char *(b[8])の話になってる。すまんこ。

945:デフォルトの名無しさん
09/10/28 08:04:04
select

946:デフォルトの名無しさん
09/10/28 23:03:47
>>924
> () > []

アホ

947:デフォルトの名無しさん
09/10/28 23:38:34
>>946
なんとなくカンテーレ

948:921=919
09/10/29 00:24:38
>922

なんか、違う人間が同じ問にレスしてわけわかになっていますな。

>ならなんで
>char *(b[8]);


宣言子においては*と[]では[]の方が結びつきが強いので
char *b[8];

char *(b[8]);
は同じ。

かえって混乱するかもしれないけど『関数の仮引数の宣言部では』
void func(char b[N][8]);
void func(char b[][8]);
void func(char (*b)[8]);
は全て同等。

ついでに上のbと下のcは別物。下の宣言同士は全て同等
void g(char *c[N]);
void g(char *c[]);
void g(char **c);


>924さんはもちろん理解していると思うけど、
>間接参照するときは、(*b)[i]のようにしないと
いやそこは普通はb[0][i]になるよね。

949:デフォルトの名無しさん
09/10/29 00:56:38
>>908-909
ざっと見て2つほど明らかなバグがあるけど面倒なので詳細は説明しない。
・2つ目のwhileの条件
・k

デバッガの使い方を覚えて1行ずつトレースしてみるのいいと思うよ。


950:デフォルトの名無しさん
09/10/29 02:19:12
>>948
> >間接参照するときは、(*b)[i]のようにしないと
> いやそこは普通はb[0][i]になるよね。
ケースバイケースじゃないか?

951:デフォルトの名無しさん
09/10/29 11:05:30
C言語を学び始めたのですが文字列の扱いで詰まってしまいました。
ある文字列について、任意のn番目の文字からx文字だけ参照したいときにはどんな関数を使えばよいのでしょうか?
strcpyやstrncpyでは先頭からしか見ることができないので困っています。

//////////////////////////////
char STR[]
char Buf[]

sprintf( Buf ,"123,456\0");
//////////////////////////////

このようなコードがあるときにSTRにBufの5文字目から7文字目まで(456)だけ
コピーするにはどうすれば…

任意のトークンで区切れるstrtokも状況によっては使えそうなのですが
挙動が分からずNullエラーになってしまったりして安定しません…

952:デフォルトの名無しさん
09/10/29 11:10:07
>>951
sprintf(Buf, "123,456\0"+4);

953:デフォルトの名無しさん
09/10/29 11:12:24
char Buf[10];
char *str = "123,456\0";
int start = 5;
int end = 7;
sprintf(Buf, "%.*s", end - start + 1, str + start - 1);

954:デフォルトの名無しさん
09/10/29 11:24:15
速やか過ぎる返信ありがとうございます。

>>952のも>>953のもどちらも実行結果は正しいのですが
肝心の何故こうなるのかが理解できてません。ダメジャンorz

>>952の方のはsprintf関数の挙動を調べればなんとなく分かりそうなのですが(文字列操作に+4って何事?状態)
>>953のお方のは正直何が起こっているのかさっぱりです。ポイン・・・タ・・・?

とにかくとっかかりは掴めたのでもう少し調べてみようと思います。ありがとうございました

955:デフォルトの名無しさん
09/10/29 11:27:00
Buf+4 は &Buf[4] と同じ・・・ と言ってもわからないだろうか?
正直、ポインタの理解なしに文字列操作は厳しいと思う

956:デフォルトの名無しさん
09/10/29 11:32:45
>>955
>Buf+4 は &Buf[4] と同じ
だということを今知ったレベルでした。
ポインタはなんとなーく概念的にはつかんでいるものの使いこなすには至らず逃げてばかりだったので…
ネットワーク間でデータをやりとりしたいため文字列操作に手を出さざるを得なくなったのですが
ポインタの基礎から把握していないと駄目っぽいですね…

957:953
09/10/29 11:37:57
こう書けば読めたりするだろうか。

char str[10];
strcpy(str, "123,456");
sprintf(Buf, "%.3s", str[5-1]); /* 5文字目の添え字は4 */

958:951
09/10/29 11:47:59
>>957
お恥ずかしながらフォーマット指定子で .[整数] ってなんだっけ…レベルです。
そして%sでstr[4]を指定すると何故5文字目以降が参照されるのかもしっかり把握していません。

後者は
sprintf(Buf,"%s",str);
は str[0]から\0にぶつかるまで参照していたということなのでしょうか。

とにかく、今やってみたおかげで>>957に類するコードを入力したら
何故かは知らないけどこうなる!というのが分かる状態になりました…
がそんなんでは使いものになりませんよね

959:デフォルトの名無しさん
09/10/29 11:52:29
>>958
プログラムは向いていない。

960:デフォルトの名無しさん
09/10/29 11:53:18
そもそも"123,456\0"と言う風に'\0'を文字列リテラルに入れている時点で文字列操作を理解していないことが判るじゃないか。

961:デフォルトの名無しさん
09/10/29 12:02:16
悔しいけども正論過ぎて泣いた。

本なりサイトなりで勉強し直すのが一番早そうですね。
丁寧に教えて下さった方、ありがとうございました。

\0を手動で入れていたのは、
ネットワークから送り込まれてくるデータがバッファに際限なく溜まっていってしまうため
区切りとして入れたのですがきっとそんなことになってしまう時点で何かがおかしいんですねわかります。

962:953
09/10/29 12:08:20
>>958
%[整数1].[整数2]s
と書くと、最低でも[整数1]幅、最大でも[整数2]幅という指定になる
最低幅に足りない場合は先頭にスペースが埋められ、最大幅を超えた部分は切り捨てられる。

ネットワーク間でのデータやりとりだと、最大幅に足りない場合は後ろにスペースを埋めたいという
ニーズもあるかと思う。
その場合は
%-[整数1].[整数2]s
とすればいい。

そのうち慣れるからがんばれ。

963:デフォルトの名無しさん
09/10/29 12:15:15
>>961
ネットワークから流れてくるものは文字列ではない。あれは只のバイト列だ。
と言う意識がないといつまでもカスみたいなコードしか書けないよ。
# 某SIerのプロパーがまさしくそれなんだが……
神経質な人は、文字列で扱うときはcharでバイト列として扱うときは(unsigned charをtypedefした)BYTEにしているくらいだ。
# それはそれで、文字列系の標準関数を使うたびにキャストする必要があるので時としてあれだけど。

964:デフォルトの名無しさん
09/10/29 12:18:29
>>961
?
バッファに際限なくたまるというのは確かにそうなってる時点でなんか変だと思う。
recv近辺のコードを上げてくれたらなんか分かるかも。

965:951
09/10/29 12:27:47
>>963
なるほど、覚えておくと見やすくなるだけでなく色々活用できるんですねえ…

>>963
今まで平気で文字列として扱ってきたのですがバイトだったのですか!
…それを知ったところで今すぐ何かが変わるわけじゃないのが不勉強なところですが
保存したレスをいつか発掘したら意味がちゃんと分かるようになってるといいなあ…

>>964
相談したいのは山々なのですが
ネットワーク周りはDXライブラリの関数を使用しているので
ここだとスレ違いな気がするのです。

966:デフォルトの名無しさん
09/10/29 12:40:43
>>965
念の為に捕捉。
>963は、ナル文字で終端されていることがはっきりしている場合を文字列と言っている。
終端されていないものにはstrlen()やstrcpy()などの関数が使えないから、意識しておかないとね。
だからと言って、受信バッファより多めにメモリを確保して事前にクリアするなんてのは下策。
尚sprintf()の場合は、>962にあるようにサイズ制限ができるからバイト列に対しても使えなくはない。

967:デフォルトの名無しさん
09/10/29 12:46:22
>>966
> >>963は、ナル文字で終端されていることがはっきりしている場合を文字列と言っている。
別に>>963がどうとかじゃないよね。
Cにおける文字列の定義の話でしょ。

968:デフォルトの名無しさん
09/10/29 13:02:58
>>967
異論避け。それほど他意はない。

969:デフォルトの名無しさん
09/10/29 14:38:26
1から40までの数のなかで、3がつく数字とさんの倍数をすべて表示するプログラムを教えてください。

970:デフォルトの名無しさん
09/10/29 14:43:03
>>969
puts("3 6 9 12 13 15 18 21 23 24 27 30 31 32 33 34 35 36 37 38 39");

971:デフォルトの名無しさん
09/10/29 14:44:44
>>969
#include <stdio.h>
#include <string.h>
int main(void) {
  int i;
  char buf[32];
  for(i = 1; i <= 40; i++) {
    sprintf(buf, "%d", i);
    if (i % 3 == 0 || strchr(buf, '3') != NULL) {
      printf("%d\n", i);
    }
  }
  return 0;
}

972:デフォルトの名無しさん
09/10/29 15:59:09
#define _XOPEN_SOURCE
#include <stdio.h>
#include <unistd.h>
int main()
{
char a[100];

*a = crypt("hogehoge", "EV");
printf("%s", a);

return 0;
}
crypt関数について調べようと思ってこんなん作ったんだけどaに何も入らないのはなぜ?
crypt関数自体がアレなのかなと思って
int main()
{
char a[100];

  printf("%s", crypt("hogehoge", "EV"));

return 0;
}
を試しに実行してみたけどこれはまともに動いた。

973:デフォルトの名無しさん
09/10/29 16:12:20
gcc -Wall

974:デフォルトの名無しさん
09/10/29 16:19:50
>>972
char a[100]; の時、a は &a[0] と同じ
つまり、*a はa[0]と同じ
a[0] = crypt・・・
が変なのはわかるだろ。
strcpy使え。

975:デフォルトの名無しさん
09/10/29 16:22:14
*a = crypt("hogehoge", "EV");

a[0] = (char)crypt("hogehoge", "EV");
と同じ

976:デフォルトの名無しさん
09/10/29 16:49:46
C言語学びはじめてもうすぐ半年になるが、いつになったらタッチタイピングできるようになるんだ

977:デフォルトの名無しさん
09/10/29 16:57:47
>>976
英語配列に変えてみた、、がまだ慣れない。

978:デフォルトの名無しさん
09/10/29 17:53:51
>>976
プログラミングとタッチタイピングを同時に学ぼうと言うのがそもそも間違い。
プログラミングは、基本的にキー入力速度が速い必要はないからね。

979:デフォルトの名無しさん
09/10/29 18:11:08
どうせなら C でタイピング練習ゲーム作ったらどうか。

980:デフォルトの名無しさん
09/10/29 20:11:55
ビット演算について質問です
char aの上位4バイトに 64以下の整数char bを代入したい場合、
(a & 0b00001111) +  (b << 4)
でできるのはわかるのですが、
もっと単純な表記方法はあるでしょうか?

981:デフォルトの名無しさん
09/10/29 20:14:17
ゲームセンターにあるタイピングオブザデッドに憧れてタイピング練習しはじめて
ローマ字覚える前にタッチタイピングマスターしちまったなぁ
最近出た第二弾はわからんがタイピング覚える気ならゾンビ打マジおすすめ
本当の意味でゲーム感覚で覚えられるタイピングソフト
他にもいろいろタイピングソフトやってみたがまともなのはこれしかなかった
スレチごめんね

982:デフォルトの名無しさん
09/10/29 20:17:20
環境によっては
union {struct {unsigned ah:4; unsigned al:4} s; char c} a;
として
a.s.ah = b;
と書ける。
或いは、
a = (a % 16) + (b * 16);
とも書ける。
いずれの場合も、bが16以上の場合は破綻する。

983:デフォルトの名無しさん
09/10/29 20:18:43
>>980
>char aの上位4バイトに 64以下の整数char bを代入したい場合、
char aの上位4ビットに 15以下の整数char bを代入したい場合、

の書き間違いかな?

984:デフォルトの名無しさん
09/10/29 20:19:17
>>980
charの上位4バイトってなんだよpgr

985:980
09/10/29 20:19:56
>982
どうも
4ビットって64じゃなくて16でしたね…
こんなんでビット演算とかやらない方が安全か

986:デフォルトの名無しさん
09/10/29 21:11:02 BE:284013465-DIA(352353)
次スレ立てました
C言語なら俺に聞け(入門篇) Part 55
スレリンク(tech板)

987:デフォルトの名無しさん
09/10/29 22:10:01
>>985

「こんなんで・・・」はないと思うぞ。
1ビットでも必要な時はビット演算をする。

そもそも何のためにやるのかだよね。

988:デフォルトの名無しさん
09/10/29 23:37:27
>>957


989:デフォルトの名無しさん
09/10/29 23:47:58
屁こくな

990:デフォルトの名無しさん
09/10/29 23:52:11
間違いの指摘するならちゃんと教えてやれよ。
まあ、うっかりミスだろうから指摘するまでもないが。

991:デフォルトの名無しさん
09/10/30 00:56:33
>>982
そのunionの使い方って厳密には保証されないんじゃないっけ?

992:デフォルトの名無しさん
09/10/30 00:58:54
俺にはその間違い探し難しすぎるぜ

993:デフォルトの名無しさん
09/10/30 08:44:31
>>991
上下どちらのビットから割り付けるかは処理系定義なので
移植性はないけどもどっちかに決まっているはず。

994:デフォルトの名無しさん
09/10/30 09:46:08
ume

995:デフォルトの名無しさん
09/10/30 09:50:06
>>991
処理系によっては、妙な割り付け方をするかもしれないね。

996:デフォルトの名無しさん
09/10/30 10:02:19
ume

997:デフォルトの名無しさん
09/10/30 10:04:35
age

998:デフォルトの名無しさん
09/10/30 10:18:54
>>992
>957のことなら、& str[5 - 1]だ。

999:デフォルトの名無しさん
09/10/30 10:18:59
ume

1000:デフォルトの名無しさん
09/10/30 10:21:41
03e8

1001:1001
Over 1000 Thread
このスレッドは1000を超えました。
もう書けないので、新しいスレッドを立ててくださいです。。。


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

5147日前に更新/215 KB
担当:undef