C言語学習 - 構造補足
序文
実際の開発およびアプリケーション シナリオでは、single int、char、double およびその他のタイプのデータは使用の要件を満たすことができず、構造は特定のイベントおよび情報を非常に適切に表すことができます. 以下は、以下を含む構造の知識を確認するプロセスの記録です。配列とポインターの構造定義、使用、および包括的な適用例。
1. 構造の定義
- Struct は構造体のキーワードです.構造体を次のように定義します:構造体+名前.定義の後, " } " の後に " ; "を追加する必要があります.
- 構造体の定義が終了すると、struct Student は全体としてint、char、floatと同等になります。
- 実際の関数で使用する場合、定義は int Dataと同じであり、struct Student Data
#include <stdio.h>
#include <string.h>
struct Student//struct 结构体关键字
{
int num;
char name[32];
char sex[32];
int age;
double score;
char addr[32];
};
struct Day//描述事件/整体
{
int year;
int month;
int day;
};
int main()
{
struct Student RenYuJie;
struct Student sd1={
2,"张三","b",24,99,"北京"};//定义时使用
return 0;
}
2.構造の使用
構造体の定義が完了したら、関数内で関連する代入および計算操作を実行するときに、構造体内の要素を呼び出す必要があります. 呼び出し方法には、主に 2 つの方法があります。
- " . " ドット演算子 -構造体名.要素
- " -> " 演算子 -構造アドレス -> 要素(つまり:構造ポインタ -> 要素)
#include <stdio.h>
#include <string.h>
struct Student//struct 结构体关键字
{
int num;
char name[32];
char sex[32];
int age;
double score;
char addr[32];
};
struct Day//描述事件/整体
{
int year;
int month;
int day;
};
int main()
{
struct Student RenYuJie;
struct Student sd1={
2,"张三","b",24,99,"北京"};//定义时使用
RenYuJie.num=1;//点运算符访问成员变量
strcpy(RenYuJie.name,"Renyujie");
strcpy(RenYuJie.sex,"man");
RenYuJie.age=24;
RenYuJie.score=100;
printf("学号:%d;性别:%s\n",RenYuJie.num,RenYuJie.sex);
(&RenYuJie)->num=9;//->访问成员变量
printf("学号:%d;性别:%s",RenYuJie.num,RenYuJie.sex);
return 0;
}
#include <stdio.h>
#include <string.h>
//结构体指针定义、使用
//1、变量名访问用点运算符;
//2、地址访问用地址->运算符
struct RenYuan
{
int num;
char name[38];
};
int main()
{
struct RenYuan one[2]={
{
1,"ryj"},{
2,"yj"}};
struct RenYuan *p;
p=one;
int len=sizeof(one)/sizeof(one[0]);
for(int i=0;i<len;i++)
{
printf("%d号选手的名字是%s\n",(p+i)->num,(p+i)->name);//变量名访问用点运算符;地址访问用地址->运算符
}
}
3. 構造体、配列、ポインタの単純な組み合わせ
int arry[3 ] が arry 配列に 3 つの整数データがあることを意味するように、 struct Student arry[3] はarry 配列に 3 つの構造体データがあることを意味します。
#include <stdio.h>
//结构体和数组的结合
struct Student//struct 结构体关键字
{
int num;
char name[32];
char sex[32];
int age;
double score;
char addr[32];
};
int main()
{
int arr[3]={
1,2,3};
struct Student arr2[3]={
{
2,"张三","b",24,99,"北京"},{
3,"李四","g",24,89,"上海"},{
4,"王五","b",21,49,"天津"}};
struct Student *p;
p=arr2;
int len=sizeof(arr2)/sizeof(arr2[0]);
for (int i=0;i<len;i++)
{
printf("%d号选手%s的分数是%f\n",(p+i)->num,(p+i)->name,(p+i)->score);
}
p=arr2;//指针归位
}
4. 構造体と配列の単純な組み合わせ
単純な投票システム(例として 5 人の有権者と 3 人の候補者) を取り上げて、構造体と配列の単純な組み合わせの適用を練習します。
#include <stdio.h>
#include <string.h>
//结构体、数组、函数、简单应用
struct XuanMing
{
char name[32];
int tickets;
};
int main()
{
struct XuanMing xm[3];
int i;
int len;
char tmpName[32];
int key=0;
struct XuanMing max;
len =sizeof(xm)/sizeof(xm[0]);
//=====================================
//============初始化选民信息===========
//=====================================
for(i=0;i<len;i++)
{
xm[i].tickets=0;
printf("请输入第%d个选民的名字:\n",i+1);
scanf("%s",&xm[i].name);
}
//=====================================
//===============唱票环节==============
//=====================================
for(i=0;i<5;i++)
{
printf("您将投票给谁?\n");
memset(tmpName,'\0',sizeof(tmpName));//每次清空一下
scanf("%s",&tmpName);
for(int j=0;j<len;j++)
{
if(strcmp(tmpName,xm[j].name)==0)
{
xm[j].tickets++;
key=1;
}
}
if(key==0)
{
printf("本次选举没有此人,视为弃票!!!\n");
}
}
//======================================
//============信息输出环节==============
//======================================
for(i=0;i<len;i++)
{
printf("%s的总票数为:%d\n",xm[i].name,xm[i].tickets);
}
//======================================
//==============排序环节================
//======================================
max=xm[0];
for(i=0;i<len;i++)
{
if(max.tickets<xm[i].tickets)
{
max=xm[i];
}
}
printf("本次投票的结果为%s:\n",max.name);
printf("%s的总票数为:%d\n",max.name,max.tickets);
}
5. 構造体、配列、ポインター、および関数の包括的な適用
#include <stdio.h>
#include <string.h>
//结构体、数组、指针、函数综合应用
struct XuanMing
{
char name[32];
int tickets;
};
void initSelectInformation(struct XuanMing *pxm,int len)
{
for(int i=0;i<len;i++)
{
(pxm+i)->tickets=0;
printf("请输入第%d个选民的名字:\n",i+1);
scanf("%s",&(pxm+i)->name);
}
}
void computeSelectInformation(int sizeRen,struct XuanMing *pxm,int len)
{
int key=0;
char tmpName[32];
for(int i=0;i<sizeRen;i++)
{
printf("您将投票给谁?\n");
memset(tmpName,'\0',sizeof(tmpName));//每次清空一下
scanf("%s",&tmpName);
for(int j=0;j<len;j++)
{
if(strcmp(tmpName,(pxm+j)->name)==0)
{
(pxm+j)->tickets++;
key=1;
}
}
if(key==0)
{
printf("本次选举没有此人,视为弃票!!!\n");
}
}
}
void claimSelectInformation(struct XuanMing *pxm,int len)
{
for(int i=0;i<len;i++)
{
printf("%s的总票数为:%d\n",(pxm+i)->name,(pxm+i)->tickets);
}
}
void maxSelectInformation(struct XuanMing *pxm,int len)
{
struct XuanMing max;
max=*(pxm);
for(int i=0;i<len;i++)
{
if(max.tickets<(pxm+i)->tickets)
{
max=*(pxm+i);
}
}
printf("本次投票的结果为%s:\n",max.name);
printf("%s的总票数为:%d\n",max.name,max.tickets);
}
int main()
{
struct XuanMing xm[3];
struct XuanMing *pxm;
pxm=xm;
int len =sizeof(xm)/sizeof(xm[0]);
int sizeRen=5;
//============初始化选民信息===========
initSelectInformation(pxm,len);
//===============唱票环节==============
computeSelectInformation(sizeRen,pxm,len);
//============信息输出环节=============
claimSelectInformation(pxm,len);
//==============排序环节===============
maxSelectInformation(pxm,len);
}