2016年4月4日月曜日

C言語:ファイルの入出力

問題1
下記の条件で、5人分キーボードから入力し、
それをディスク上にファイルとして生成するプログラムを作成。
・受験番号(4ケタ)
・性別(男:M、女:F)
・氏名(20ケタ以内、姓と名の間を"-"でつなぐ)

問題2
問題1で生成したファイルを読み込み、まず性別で分け、
その中を氏名順でソートするプログラムを作成。

問題1のプログラム
struct exam{
  int no;
  char sex;
  char first[10];
  char last[10];
};

int main(void){
  FILE *fp;
  int i;
  struct exam member[10];
  for(i=0;i<5 i="" p="">    printf("%d番目の受験番号を入力してください:",i+1);
    scanf("%d", &member[i].no );
    printf("%d番目の性別を入力してください M/F:",i+1);
    scanf(" %[MF]", &member[i].sex );
    printf("%d番目のファーストネームを入力してください:",i+1);
    scanf("%s", member[i].first );
    printf("%d番目のラストネームを入力してください:",i+1);
    scanf("%s", member[i].last );
  }
   fp = fopen("test.txt","a");
   for(i =0;i<5 i="" p="">        printf("受験番号:%d\n性別:%c\n氏名:%s-%s\n",member[i].no, member[i].sex, member[i].first,member[i].last);
        fprintf(fp,"%d %c %s-%s\n",member[i].no, member[i].sex, member[i].first,member[i].last);
    }
   fclose(fp);
   printf("test.txtに出力完了\n");

  return 0;
}


問題2のプログラム
typedef struct {
  int no;
  char sex[5];
  char name[20];
} exam;
int main(void){
  FILE *fp;
  int  i,j,s=0,t=0;
  exam member[10];
  exam male[10],female[10],x[1],y[1];
  fp = fopen("test.txt","r");
  // ファイルの終端まで文字列を読み取り表示
  for(i=0;i<5 div="" i="">
      if(fscanf(fp,"%d %s %s\n" ,&member[i].no,member[i].sex, member[i].name ) != 3 ) break;
  }
  fclose(fp);
  //性別ごとに分類
  printf( "女性だけ表示\n");
  for (i=0;i<5 div="" i="">
    if(strcmp(member[i].sex,"M")){
     female[t].no = member[i].no;
     strcpy(female[t].sex,member[i].sex);
     strcpy(female[t].name,member[i].name);
     printf( "%d %s %s\n", female[t].no, female[t].sex, female[t].name);
     t++;
    }
  }
  printf( "男性だけ表示\n");
  for (i=0;i<5 div="" i="">
    if(strcmp(member[i].sex,"F")){
     male[s].no = member[i].no;
     strcpy(male[s].sex,member[i].sex);
     strcpy(male[s].name,member[i].name);
     printf( "%d %s %s\n", male[s].no, male[s].sex, male[s].name);
     s++;
   }
  }
  //女性の並べ替え
  for(i=0;i
    for(j=0;j
      if (strcmp(female[j].name,female[j+1].name) > 0) {
         y[1] = female[j];
         female[j] = female[j+1];
         female[j+1] = y[1];
      }
    }
  }
  printf( "女性を氏名順に並び替え\n");
  for(i=0;i
     printf( "%d %s %s\n",  female[i].no, female[i].sex, female[i].name);
  //男性の並べ替え
  for(i=0;i
    for(j=0;j
      if (strcmp(male[j].name,male[j+1].name) > 0) {
         x[1] = male[j];
         male[j] = male[j+1];
         male[j+1] = x[1];
      }
    }
  }
  printf( "男性を氏名順に並び替え\n");
  for(i=0;i
     printf( "%d %s %s\n",  male[i].no, male[i].sex, male[i].name);
  return 0;
  }

2016年2月26日金曜日

C言語:構造体

問題1
受験番号(4桁)と氏名(20文字以内)を5人分入力し、番号順とアルファベット順の
2種類のリストを出力するプログラムを、構造体を用いて作成。

問題2
下記の作家は「このマンガがすごい!オトコ編」と「マンガ大賞」の受賞者で、数字は受賞年を表す。
これを構造体を用いて表し、賞別、受賞年順にソーティングするプログラムを作成。
一番右の"K"、"M"はそれぞれ"このマンガがすごい!"、"マンガ大賞"を示す。

Koyama    - Chuya        2009    M
Murata    - Yusuke       2014    M
Sasuga    - Yu           2013    K
Umino     - Chika        2011    M
Ooima     - Yoshitoki    2015    K
Suetsugu  - Yuki         2010    M
Matsui    - Yusei        2015    K
Yoshimoto - Koji         2012    K

問題1のプログラム
struct exam{
  int no;
  char name[20];
};

int main(void)
{
  int i,j;
  struct exam member[10];
  for(i=0;i<5 d="" for="" i="0;i<5;i++)" j="4;j" member="" name="" no="" printf="" s="" scanf="">i;j--) {
        if (member[j-1].no>member[j].no)
           {
            member[6] = member[j];
            member[j] = member[j-1];
            member[j-1]= member[6];
           }
      }
  }
        printf("番号順にソート\n");
  for(i =0;i<5 d="" for="" i="0;i<5;i++)" j="4;j" member="" n="" name="" no="" printf="" s="">i;j--) {
        if(strcmp(member[j-1].name,member[j].name)>0)
           {
            member[6] = member[j];
            member[j] = member[j-1];
            member[j-1]= member[6];
           }
      }
   }
        printf("アルファベット順にソート\n");
   for(i =0;i<5 0="" d="" i="" member="" n="" name="" no="" pre="" printf="" return="" s="">
        printf("受験番号:%d 氏名:%s\n",member[i].no, member[i].name);
    }
  return 0;
}

問題2のプログラム
struct exam{
  int no;
  char name[20];
};

int main(void)
{
  int i,j;
  struct exam member[10];
  for(i=0;i<5 d="" for="" i="0;i<5;i++)" j="4;j" member="" name="" no="" printf="" s="" scanf="">i;j--) {
        if (member[j-1].no>member[j].no)
           {
            member[6] = member[j];
            member[j] = member[j-1];
            member[j-1]= member[6];
           }
      }
  }
        printf("番号順にソート\n");
  for(i =0;i<5 d="" for="" i="0;i<5;i++)" j="4;j" member="" n="" name="" no="" printf="" s="">i;j--) {
        if(strcmp(member[j-1].name,member[j].name)>0)
           {
            member[6] = member[j];
            member[j] = member[j-1];
            member[j-1]= member[6];
           }
      }
   }
        printf("アルファベット順にソート\n");
   for(i =0;i<5 0="" 13_2.c="" cat="" d="" i="" include="" iwakami="" kadai13="" localhost="" master="" member="" n="" name="" no="" printf="" return="" s="" stdio.h="">

struct manga {
        char name[30];
        int year;
        char award;
};

int main(void)
{
        int i,j;
        struct manga member[10] = {
          {"Koyama    - Chuya    ", 2009, 'M'},
          {"Murata    - Yusuke   ", 2014, 'M'},
          {"Sasuga    - Yu       ", 2013, 'K'},
          {"Umino     - Chika    ", 2011, 'M'},
          {"Ooima     - Yoshitoki", 2015, 'K'},
          {"Suetsugu  - Yuki     ", 2010, 'M'},
          {"Matsui    - Yusei    ", 2015, 'K'},
          {"Yoshimoto - Koji     ", 2012, 'K'},
        };
               printf("構造体を用いて表示\n");
        for(i = 0; i < 8; i++) {
                printf("%s %d %c\n",member[i].name, member[i].year, member[i].award);
        }

        //賞別にソート
        for (i=0;i<8 for="" i="" j="7;j">i;j--) {
               if (member[j-1].award > member[j].award)
                  {
                   member[9] = member[j];
                   member[j] = member[j-1];
                   member[j-1]= member[9];
                  }
             }
         }
     //賞ごとに受賞年順をソート
        for (i=0;i<8;i++) {
           for (j=7;j>i;j--) {
               if ((member[j-1].year > member[j].year)&&(member[j-1].award==member[j].award))
                  {
                   member[9] = member[j];
                   member[j] = member[j-1];
                   member[j-1]= member[9];
                  }
             }
         }
               printf("賞別、受賞年順にソート\n");
         for(i =0;i<8;i++) {
               printf("%s %d %c\n",member[i].name, member[i].year, member[i].award);
           }
return 0;
}

2016年2月3日水曜日

C言語:関数


問題1.
キーボードから正の整数を1つ入力し、それが偶数か奇数かを判断し、偶数なら
    "今入力した整数~は偶数である"
と出力し、奇数の場合も同じように出力するプログラムを関数を用いて作成。
偶数・奇数の判断は関数で行い、入出力はmainで行う。

問題2.
下記のプログラムの*で囲った部分を関数とするプログラムに書き換え。
[プログラム説明]
1~100までの間のすべての素数を求めるプログラム
#define MAX_LENGTH 100
int main(){
    int a[MAX_LENGTH+1], i, n, k;

    for(i=0; i<=MAX_LENGTH; i++)
        a[i] = i;

    n = sqrt(100.0);
*************************************************
    for(k=2; k<=n; k++){
        if(a[k] == 0)
            continue;
        for(i=k*2; i<=MAX_LENGTH; i=i+k)
            a[i] = 0;
    }
*************************************************
    printf("1から100までの素数は以下の通り\n");

    for(i=1; i<=MAX_LENGTH; i++)
        if(a[i] != 0)

    printf("%d ", a[i]);
    printf("\n");
}

問題1のプログラム
int g(int),k(int);
int main(void){
  int x;
  printf("正の整数を入力してください。:");
  scanf("%d",&x);
  g(x);k(x);
  return 0;
}

int g(int s){
  if(s%2==0){
    printf("今入力した整数%dは偶数である。\n",s);
  }
}

int k(int t){
  if(t%2!=0){
    printf("今入力した整数%dは奇数である。\n",t);
  }
}

問題2のプログラム
#define MAX_LENGTH 100

int a[MAX_LENGTH+1], i, n, k;
int prime_num(int);
int main(){
    for(i=0; i<=MAX_LENGTH; i++)
        a[i] = i;

    n = sqrt(100.0);
    prime_num(n);
    printf("1から100までの素数は以下の通り\n");
    for(i=1; i<=MAX_LENGTH; i++)
        if(a[i] != 0)
    printf("%d ", a[i]);
    printf("\n");
}

int prime_num(int x)
{   for(k=2; k<=x; k++){
        if(a[k] == 0)
            continue;
        for(i=k*2; i<=MAX_LENGTH; i=i+k)
            a[i] = 0;
    }
}

2016年1月24日日曜日

C言語:ポインタ

問題1.
変数aの内容と変数bの内容を入れかえるプログラムを、ポインタを用いて作成してください。

問題2.
1から100までの和を求めるプログラムを、ポインタを用いて作成してください。

問題3.
キーボードから10個の整数を配列に入れ、その中の最大値を求めるプログラムを
ポインタを用いて作成してください。

問題4.
下記のソーティングプログラムを、ポインタを用いたものに書き換えてください。

[プログラム説明]
適当な整数を10個キーボードから入力し、そのソート前とソート後の結果を表示するプログラム。

[プログラム]
int main() {
    int a[10], i, j, w;
    printf("整数を10個入力しなさい\n");
    for(i=0; i<=9; i++)
        scanf("%d", &a[i]);
    printf("ソート前… ");
    for(i=0; i<=9; i++)
        printf("%d ", a[i]);
    for(i=0; i<=9; i++)
        for(j=0; j<=9-1; j++)
            if(a[j] > a[j+1]){
                w = a[j];
                a[j] = a[j+1];
                a[j+1] = w;
            }
    printf("\nソート後… \n");
    for(i=0; i<=9; i++)
        printf("%d ", a[i]);
}
問題5.
下記のプログラムにおいて、データにない頭文字が入力されてきたとき
"該当するデータはありません"
と出力されるように、修正を加えてください。

[プログラム説明]
適当に5人の名前を選び、それらの名前をローマ字でポインタ型の配列に初期設定する。
キーボードから英大文字1字を入力し、その英字を名前の先頭にもつ人だけを出力するプログラム。

[プログラム]
int main() {
    char head, *name[5]={"Shibasaki", "Usami", "Muto", "Miyaichi", "Kushibiki"};
    int i;
    printf("英大文字を1字入力しなさい\n");
    scanf("%c", &head);
    printf("%cを先頭に持つ名前は…", head);
    for(i=0; i<=4; i++)
        if(*name[i] == head)
            printf("%s ", name[i]);
    printf("\n");
}

問題1のプログラム
int main(void){
  int *pa,*pb,*x;
  int a = 1,b = 2;
  printf("変数:a=%d  b=%d\n", a,b);
  pa = &a;
  pb = &b;
  printf("入れ替え前:ポインタpa=%d  ポインタpb=%d\n", *pa,*pb);
  x  = pa;
  pa = pb;
  pb = x;
  printf("入れ替え後:ポインタpa=%d  ポインタpb=%d\n", *pa,*pb);
  return 0;
}

問題2のプログラム
int main(void){
  int a = 1,x = a;
  int *pa;
  for (a=2;a<=100;a++){
     x = x + a;
     pa = &x;
  }
  printf("1から100までの和は%d\n",*pa);
}

問題3のプログラム
int main(void){
  int a[10],i,max;
  int *p,*s;
  for(i=0;i<10 i="" p="">    printf("整数を10個入力してください:");
    scanf("%d",&a[i]);
  }
  p = a;
  for(i=1,max=*p;i<10 i="" p="">    if(max<*(p+i)){
      max = *(p+i);}
  }
 printf("最大値は%d",max);
}

問題4のプログラム
int main() {
    int a[10], i, j, w;
    int *p;
    printf("整数を10個入力しなさい\n");
    for(i=0; i<=9; i++)
        scanf("%d", &a[i]);
    //ポインタに配列を代入
    p = a;
    printf("ソート前… ");
    for(i=0; i<=9; i++)
        printf("%d ", *(p+i));
    for(i=0; i<=9; i++)
        for(j=0; j<=9-1; j++)
            if(*(p+j) > *(p+j+1)){
                w = *(p+j);
                *(p+j) = *(p+j+1);
                *(p+j+1) = w;
            }
    printf("\nソート後… ");
    for(i=0; i<=9; i++)
        printf("%d ", *(p+i));
}

問題5のプログラム(これはもっと良い方法があると思うな...)
int main() {
    char head, *name[5]={"Shibasaki", "Usami", "Muto", "Miyaichi", "Kushibiki"};
    int i,j=0;
    printf("英大文字を1字入力しなさい\n");
    scanf("%c", &head);
    printf("%cを先頭に持つ名前・・・", head);
    for(i=0; i<=4; i++){
        if(*name[i] == head){
            printf(" %s", name[i]);
            j++;
        }
      }
        if(j==0)printf("該当するデータはありません");
    printf("\n");
}

2016年1月16日土曜日

Mosaik - Rubik

The man is absorbed in thought on the subject of flow.HNY2016;-)

2016年の12分の1の半分ほどが過ぎてしまったけど、
あらためまして、あけましておめでとうございます。

2015年、27歳になった年は瞬く間に過ぎました。

甥っ子がもうすぐ2歳になる。その甥っ子にとっての一年は人生のほとんどだったわけで、
27年も生きていると、自分の人生を構成する時間がだんだんと薄まっていくのは同然のことのようにも思える。
かと言って、この一年は無下にはしないし、すくすく育つ甥っ子とも仲良くやっていきたい。

おかげさまで、季節の変わり目に風邪を引きつつも、おおむね健康な一年を過ごせたと思う。

去年の年始に達磨を買った。ちゃんと片方の黒目だけ塗って、
目標を定めていたんだけど、完全な形ではないにしても達成することが出来た。
今年はもうひと回り大きな達磨を買う予定。

2015年2月に掲げたやりたいことは↓だった。

  1. 自分の持っていたいビジョンに沿って、仕事・ライフスタイルを再考する。行動する。
  2. 知人のサービスを手伝う。ノウハウを学習する。個人としての能力を高める。
  3. 個人の能力で何かしら成果物を世に出し、お金を稼ぐ。
5点満点で上から、
3.5点
4点
3.5点
という印象。振り返るとなかなかよくやったんじゃないかとも思えるし、
まだまだ出来ることがあったようにも思える。
世話になってる人に迷惑掛けてしまったこともあって、もっともっと自分自身の能力を高めていきたい。

あと、2015年の特に後半は、運動にも意識して時間を割くことが出来た。運動は素晴らしい。
気持ちもポジティブになるし、肉体を稼働させると心体ともに好循環。

かくして、2012年あたりから精進路線として、
楽しいと思える努力をしようとか、個人の能力を高めて所属組織以外でも役に立つ能力を研鑽しようとか、一応はブレない方針で月日を過ごしている。

2016年の目標としては、

  1. ゾーン、フローに入る時間を増加させる
  2. やらないことを決める
  3. 頼る、アウトソースする
と、考えてる。
おそらく今年は自分史上もっとも時間的制約を受けながら、
自分が達成したいスキルや勉学などいくつか重なる年になると思う。


  • ゾーン、フローに入る時間を増加させる
普段の仕事とか資格をとるとかぐうたら過ごす時間とか、自分の時間を切り売りして生活してるわけだけど、
時間の質を高めて、短い時間でもっと成果をあげることができたら、余った時間で休んだり他に回したりすることができる。
特にフローの状態に入れれば、目の前のやるべきことに自我を意識せず没入できる。

(フローについてはwikiから)
フローとは、人間がそのときしていることに、完全に浸り、精力的に集中している感覚に特徴づけられ、完全にのめり込んでいて、その過程が活発さにおいて成功しているような活動における、精神的な状態をいう。
チクセントミハイが見たところによれば、明確に列挙することができるフロー体験の構成要素が存在する。彼は8つ挙げている。
  1. 明確な目的(予想と法則が認識できる)
  2. 専念と集中、注意力の限定された分野への高度な集中。(活動に従事する人が、それに深く集中し探求する機会を持つ)
  3. 自己に対する意識の感覚の低下、活動と意識の融合。
  4. 時間感覚のゆがみ - 時間への我々の主体的な経験の変更
  5. 直接的で即座な反応(活動の過程における成功と失敗が明確で、行動が必要に応じて調節される)
  6. 能力の水準と難易度とのバランス(活動が易しすぎず、難しすぎない)
  7. 状況や活動を自分で制御している感覚。
  8. 活動に本質的な価値がある、だから活動が苦にならない。
フローを経験するためにこれら要素のすべてが必要というわけではない。フローに入るためのもう一つの重要な条件に、他者に妨害されない環境がある。電話がかかってきたり、だれかが部屋に入ってきたりといったいかなる妨害であっても、おそらくフロー経験から引きずり出され、それに対応するモードに移行してしまうだろう。
誰もがフローを経験したことがあると思う。
僕の場合だと学生時代のほうがより深く状態に入れていた記憶があって、
歳を重ねてから、背景事情とか邪念とか諸々の事情とか取り組むべき事柄に対して真っ向から集中できないことが多いように思う。
でも、昨今だと習慣がついてきたのか、このフローの精神状態により多くの時間入っていけるような気がしている。もっとこの時間を増やしたい。

  • やらないことを決める
もともとエンジニアとしてスタートしたのが遅かったこともあって、何かを学ぶことに対して抵抗がない。というか3年間出遅れた分ひとより多く吸収しなければっていう焦りの気持ちも強かった。
なんでも好き嫌いなく食べなければならないという強迫観念に囚われていた。

でも、すべからく中途半端に放り出してしまうこともあるわけで、今年は「自分はこれをやらない」と明確に定めることを意識したい。
特にIT界隈の分野だと、学習すべき幅と深さが途方も無い。今の段階では手を出すべきことでなければ、それはやらない。

  • 頼る、アウトソースする
ひとりで完結したがり。ひとりで閉じることの出来る世界をつくっていくのが好きだ。
自分の趣味や興味の範囲で完結させることは良いことだと思うけど、
仕事のやりがいに対しても同じような姿勢を求めようとすると、
どうしても、ボロがでたり、効率的でなかったり、なにかとうまくまわらない。

2つ目にも関連するけど、自分がやらないと決めたことや、誰かにお願いしたほうが最終的なアウトプットがより良いものになるのなら、その選択肢をとろう。


以上、本年もよろしくです。
フローに関しては、ミハイ・チクセントミハイさんのTEDのプレゼンテーションを貼っておきます。
ぜひ楽しんで下さい。
(´-`).。oO(このミハイ・チクセントミハイって名前は田中太郎田中的な入れ子なの...?)