第14章 结构体和其他数据形式

通讯录

#include <stdio.h>

#include <stdlib.h>

#include  <string.h>

struct inof

{

    char name[200];

    long long phone;


};

void main2( void)

{

    struct inof inof1;

    strcpy(inof1.name, "xiaofeng");

    inof1.phone = 15624024417;

    printf("%s %lld \n",inof1.name,inof1.phone);

}

void main(void )

{

    struct inof *p;

    p=(struct inof *)malloc(sizeof(struct inof));

    strcpy((*p).name, "xiaofeng1");

    (*p).phone = 15624024418;

    printf("%s %lld \n", p->name,p->phone);




}

仅包含一本图书的 图书目录 


#define use _CRT_SECURE_NO_WARNINGS

#include <stdio.h>

#include <stdlib.h>

#define MAXTTL 41

#define MAXAUTL 31

struct book{

char title[MAXTTL];

char author [MAXAUTL];

float value;

};

void main()

{

struct book bo;

printf("please enter the book title\n");

gets(bo.title);

printf("Now enter the author \n");

gets(bo.author);

printf("Now enter the value \n");

scanf("%f",&bo.value);

printf("%s    by %s %.2f \n " , bo.title,bo.author,bo.value);

system("pause");

}




包含多本书的 图书目录


#define use _CRT_SECURE_NO_WARNINGS

#include <stdio.h>

#include <stdlib.h>

#define MAXTTL 41

#define MAXAUTL 31

#define MAXBKS 100

struct book{

char title[MAXTTL];

char author [MAXAUTL];

float value;

};

void main()

{

int count = 0;

int index;

struct book library[MAXBKS];

printf("please enter the book title\n");

while (count < MAXBKS && gets(library[count].title)!= NULL && library[count].title[0] != '\0' )

{

printf("Now enter the author \n");

gets(library[count].author);

printf("Now enter the value \n");

scanf("%f",&library[count++].value);

while (getchar ()!= '\n')

{

continue;

}

if (count < MAXBKS)

{

printf("please enter the book title\n");

}

}

if (count > 0)

{

printf("here is the list of your books\n");

for ( index = 0;  index < count;  index++)

{

printf("%s    by %s %.2f \n " , library[index].title,library[index].author,library[index].value);

}

}

else

{

printf("no books to bad \n");

}

system("pause");

}

结构体嵌套

#include<stdio.h>

#include <stdlib.h>

#define LEN 20

const char* msgs[5] =

{

"think you for the wonderot",

"you certainly prove that a ",

"is a special kind of guy . we must get together ",

"over a dilicious",

"and have a few laughs "

};

struct names{

char first[LEN];

char last[LEN];

};

struct guy

{

struct names handle;

char favfood[LEN];

char job[LEN];

float income ;

};

void main()

{

struct guy fellow =

{

"enwen",

"Villard",

"grolleds",

"personality coach ",

1500002.00

} ;

printf("Dear %s \n \n ",fellow.handle.first);

printf("%s %s  \n ",msgs[0] , fellow.handle.first);

printf("%s %s  \n ",msgs[1] , fellow.job);

printf("%s    \n ",msgs[2]  );

printf("%s %s  %s \n ",msgs[3] , fellow.favfood,msgs[4]);

if (fellow.income > 1500000.0)

{

puts("!!");

}

else if(fellow.income > 75000.0)

{

puts("!");

}

else

{

puts(".");

}

printf("\n %40s %s \n" ," " ,"see you soon");

printf("\n %40s %s \n" ," " ,"shalala");

system("pause");

}


#include <stdio.h>

#include <stdlib.h>

#define LEN 20

struct names {

char first[LEN];

char last[LEN];

};

struct guy

{

struct names handle;

char favfood[LEN];

char job[LEN];

float income;

};

void main()

{

struct guy fellow[2] =

{{

"enwen",

"Villard",

"grolleds",

"personality coach ",

1500002.00

},{

"rodney",

"Swillbelly",

"tripe ",

"tabloid editor  ",

23240.00

}} ;

struct guy *him;

printf("address 1 = %p address2 = %p \n" , &fellow[0], &fellow[1]);

him = fellow;

printf("address 1 = %p address2 = %p\n" ,him, him+1);

printf("him -> income = %f  *him .income = %f\n",him->income,(*him).income);

him++;

printf("him -> income = %f  *him .income = %f",him->income,(*him).income);

system("pause");

}


把结构成员作为参数传递


#include <stdio.h>

#include <stdlib.h>

#define FUNDLEN 50

struct funds

{

    char bank [FUNDLEN];

    double bankfund ;

    char save[FUNDLEN];

    double savefund;


};

double sum(double,double);

void main()

{

    struct funds stan = {

        "Garlic-melon Bank",

        3023.72,

        "Lucky's Saviings and Loa",

        9237.11

    };


    printf("Stan has a total of %.2f.\n",sum (stan.bankfund,stan.savefund));


}

double sum(double x ,double y)

{

    return  x+ y;

}



传递指向结构体的指针

#include <stdio.h>

#include <stdlib.h>

#define FUNDLEN 50

struct funds

{

    char bank [FUNDLEN];

    double bankfund ;

    char save[FUNDLEN];

    double savefund;


};

double sum(const struct funds *);

void main()

{

    struct funds stan = {

        "Garlic-melon Bank",

        3023.72,

        "Lucky's Saviings and Loa",

        9237.11

    };

    struct  funds *p ;

    p = &stan;

    printf("Stan has a total of %.2f.\n",sum (p ));


}

double sum(const struct funds *money )

{

    return  money->bankfund + money -> savefund;



}





把结构体作为参数传递


#include <stdio.h>

#include <stdlib.h>

#define FUNDLEN 50

struct funds

{

    char bank [FUNDLEN];

    double bankfund ;

    char save[FUNDLEN];

    double savefund;


};

double sum(const struct funds );

void main()

{

    struct funds stan = {

        "Garlic-melon Bank",

        3023.73,

        "Lucky's Saviings and Loa",

        9237.11

    };

    struct  funds *p ;

    p = &stan;

    printf("Stan has a total of %.2f.\n",sum (stan));


}

double sum(const struct funds money )

{

    return  money.bankfund + money. savefund;


}

使用只想结构的指针

#include <stdio.h>

#include <stdlib.h>

#define FUNDLEN 50

struct funds

{

    char fname[20];

    char lname[20];

    int letters;


};

void getinfo (struct funds * );

void makeinfo (struct funds * );

void showinfo (const struct funds * );

void main()

{

    struct funds person;

    getinfo(&person);

    makeinfo(&person);

    showinfo(&person);

}

void getinfo(struct funds * pst)

{

    printf("please enter your first name \n");

    gets(pst -> fname);

     printf("please enter your last name \n");

     gets(pst -> lname);

}

void makeinfo(struct funds *pst)

{

    pst ->letters = strlen(pst ->fname)+ strlen(pst ->lname);


}

void showinfo(const struct funds * pst)

{

     printf("%s %s your name contains %d letters \n " ,pst -> fname ,pst ->lname,pst->letters);

}






传递和返回结构

#include <stdio.h>

#include <stdlib.h>

#define FUNDLEN 50

struct funds

{

    char fname[20];

    char lname[20];

    int letters;


};

struct funds getinfo (void );

struct funds makeinfo (struct funds );

voidshowinfo (  struct funds );

void main()

{

    struct funds person;

    person =getinfo();

    person =makeinfo(  person);

    showinfo(person);

}

struct funds getinfo (void )

{

    struct funds temp;

    printf("please enter your first name \n");

    gets(temp.fname);

    printf("please enter your last name \n");

    gets(temp.lname);

    return temp;


}

struct funds makeinfo (struct funds info)

{

    info.letters = strlen(info.fname)+ strlen(info. lname);

    return info;

}

voidshowinfo (  struct funds pst )

{

     printf("%s %s your name contains %d letters \n " ,pst.fname ,pst.lname,pst.letters);

}





使用指针和malloc

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

struct funds

{

    char *fname ;

    char *lname ;

    int letters;


};

void  getinfo (struct funds * );

void makeinfo (struct funds * );

void showinfo ( const struct funds *);

voidcleanup (  struct funds *);

void main()

{

    struct funds person;

    getinfo(&person);

    makeinfo(&person);

    showinfo(&person);

    cleanup(&person);

 }

void  getinfo (struct funds * pst)

{

    char temp[81];

    printf("please enter your first name \n");

    gets(temp);

    pst ->fname = (char *) malloc(sizeof(temp)+1);

    strcpy( pst -> fname, temp);

    printf("please enter your last name \n");

    gets(temp);

    pst ->lname = (char *) malloc(sizeof(temp)+1);

    strcpy( pst -> lname, temp);


}

void makeinfo (struct funds * info)

{

    info->letters = strlen( info->fname)+ strlen( info-> lname);


}

void showinfo ( const struct funds *pst)

{

     printf("%s %s your name contains %d letters \n " ,pst->fname ,pst ->lname,pst->letters);

}

void cleanup(struct funds *pst)

{

    free(pst->fname);

     free(pst->lname);

}




复合文字

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

#define MAXTITL 41

#define MINAUTL 41

struct book

{

    char tittle[MAXTITL] ;

    char author[MINAUTL] ;

    float value;

};

void main()

{

    struct book readfirst ;

    int score ;

    printf("please enter your score \n");

    scanf("%d",&score);

    if (score >= 84) {

        readfirst = (struct book ){"Crime and punishment",

            "Fyodor Dostoyevsky",

            9.99};

        }

    else

        readfirst =(struct book ){"mr bouncy's nice hat  ",

            "Fred winsome",

            5.99};

    printf("your assigned reading \n");

    printf("%s by %s %.2f \n ",readfirst.tittle,readfirst.author,readfirst.value);


 }




伸缩型数组成员

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

struct flex

{

    int count ;

    double average;

    double scores[];


};

void showFlex(const struct flex *p);

void main()

{

    struct flex *pf1 ,*pf2;

    int n = 5;

    int i;

    int tot =0;

  pf1 = (struct flex *)malloc(sizeof(struct flex )+n *sizeof(double));

     //pf1 =  malloc(sizeof(struct flex )+n *sizeof(double));

    pf1->count = n;

    for (i = 0 ; i < n ; i++) {

        pf1  ->scores[i] = 20.0 -i;

        tot += pf1  ->scores [i];

    }

    pf1 ->average = tot /n;

    showFlex(pf1);

    n =9;

    tot  =0;

    pf2 =  (struct flex *) malloc(sizeof(struct flex )+n *sizeof(double));

    pf2 ->count = n;

    for (i = 0 ; i < n ; i ++ ) {

        pf2 ->scores[i] = 20.0 - i /2.0;

        tot += pf2 ->scores[i];


    }

    pf2 ->average = tot/n;

    showFlex(pf2);

    free(pf1);

    free(pf2);




 }

void showFlex(const struct flex *p)

{

    int i;

    printf("score ");

    for (i = 0 ; i < p->count; i++) {

        printf("%g",p->scores[i]);


    }

    printf("\n Avergae %g \n",p->average);



}

//

//

//void  getinfo (struct funds * pst)

//{

//    char temp[81];

//    printf("please enter your first name \n");

//    gets(temp);

//    pst -> fname = (char *) malloc(sizeof(temp)+1);

//    strcpy( pst -> fname, temp);

//    printf("please enter your last name \n");

//    gets(temp);

//    pst -> lname = (char *) malloc(sizeof(temp)+1);

//    strcpy( pst -> lname, temp);

//   

//}

//void makeinfo (struct funds * info)

//{

//    info-> letters = strlen( info->fname)+ strlen( info-> lname);

// 

//}

//void showinfo ( const struct funds *pst)

//{

//    printf("%s %s your name contains %d letters \n " ,pst->fname ,pst ->lname,pst->letters);

//}

//void cleanup(struct funds *pst)

//{

//    free(pst->fname);

//    free(pst->lname);

//}


向 函数 传递 一个结构数组


#include <stdio.h>

#include <stdlib.h>

#include <string.h>

#define FUNDLEN 50

#define N 2

struct funds

{


    char bank [FUNDLEN];


    double bankfund ;


    char save[FUNDLEN];


    double savefund;




};

double sum( const struct funds money[] ,int n);

void main()

{

    struct funds jones[N]= {{"Garlic-melon bank ",3024.72,"Lucky's saving and loan ",9237.11 },{"Honset jack's bank ",3534.28,"party time savings ",3203.89}};

     printf("The JOnese have total of %.2f \n",sum(jones, N));



 }

double sum( const struct funds money[] ,int n)

{


    double total;

    int i;

    for (i = 0 ,total = 0; i < n  ; i++) {

        total +=  money[i] .bankfund + money[i].savefund;

    }


    return total;




}

#  




#include <stdio.h>

#include <stdlib.h>

#include <string.h>

#define MAXTITL 41

#define MINAUTL 41

#define MAXBKS 10

struct book

{


    char tittle[MAXTITL] ;


    char author[MINAUTL] ;


    float value;


};

void main()

{


    struct book libarary[MAXBKS]  ;

    int count = 0;

    int index , filecount;

    FILE * pbooks;

    int size = sizeof(struct book);

    if ((pbooks = fopen(".//book.dat", "a+b")) == NULL) {

        fputs("cant open book.dat file \n ", stderr );

        exit(1);


    }

    rewind(pbooks);

    while (count < MAXBKS && fread(&libarary[count], size, 1, pbooks) == 1 ) {

        if (count == 0 ) {

            puts("current contents of book.dat ");


        }

        printf("%s by%s %.2f \n ",libarary[count].tittle,libarary[count].author,libarary[count].value);

        count++;


    }

    filecount = count;

    if (count == MAXBKS) {

        fputs("the book.dat file is full ", stderr);

        exit(2);


    }

    puts("please add new book titles ");

    puts("press enter at the start of line to stop ");

    while (count < MAXBKS && gets(libarary[count].tittle) != NULL && libarary[count].tittle[0] != '\0'  ) {

        puts("now enter the author ");

        gets(libarary[count].author);

        puts("now enter the value ");

        scanf("%f",&libarary[count ++ ].value);

        while (getchar()!= '\n') {

            continue;


        }

        if (count < MAXBKS) {

            puts("enter the next title");


        }


    }

    if (count > 0) {

        puts("here  is the list of your books ");

        for (index = 0; index < count ; index ++ ) {

             printf("%s by%s %.2f \n ",libarary[index].tittle,libarary[index].author,libarary[index].value);


        }

        fwrite(&libarary[filecount], size, count - filecount, pbooks);

    }

    else puts("no books too bad \n");

    puts("bey\n");

    fclose(pbooks);

}





使用枚举值( 编译失败)

#include <stdio.h>

#include <string.h>

#include <stdbool.h>

enum spectrum{ red,orange , yellow ,green,blue,violet};

const char * colors[]={ "red","orange" , "yellow" ,"green","blue","violet"};

#define LEN 30

int main()

{

    char choice[LEN];

    enum spectrum color;

    bool color_is_found=false;

    puts("Enter a color (empty line to quit)");

    while (gets(choice) != NULL && choice[0] != '\0')

    {

        for (color = red ; color <= violet ; color++) {

            if (strcmp(choice, colors[color]) == 0) {

                color_is_found =true;

                break;

            }

        }

        if (color_is_found) {

            switch (color) {

                case red:

                    puts("Roses are red ");


                    break;

                case blue:

                    puts("Roses are red ");

                    break;

                case yellow:

                    puts("Roses are yellow ");

                    break;

                case green:

                    puts("Roses are green ");

                    break;

                case violet:

                    puts("Roses are violet ");

                    break;

                case orange:

                    puts("Roses are orange ");

                    break;

                default:

                    break;

            }

        }

        else

            printf("I Dont know about the color %s ",choice);

        color_is_found =false;

        puts("Next color p;ease (empty line to quit )");

    }

    puts("Goodbye");

}


使用函数指针



#include <stdio.h>

#include <string.h>

#include <ctype.h>

char showmenu();

void eatline();

void show(void(*fp) (char) , char * str);

void ToUpper(char*);

void ToLower(char *);

void Transpose(char *);

void Dummy(char *);

void main()

{

    char line [81];

    char copy [81];

    char choice;

    void (*pfun)(char *);

    puts("Enter a string (empty ine to quit )");

    while (gets(line) != NULL && line[0] != '\0') {

        while ((choice = showmenu() ) != 'n') {

            switch (choice) {

                case 'u':

                    pfun =ToUpper ;

                    break;

                case 'l':

                    pfun =ToLower ;

                    break;

                case 't':

                    pfun =Transpose ;

                    break;

                case 'o':

                    pfun =Dummy ;

                    break;


            }

            strcmp(copy, line);

            show(pfun, copy);


        }

        puts("enter a string emty line to quite "  );


    }

    puts("bey");


}

char showmenu(void)

{

    char ans;

    puts("Enter menu choice ");

    puts("u ) uppercase 1 ) lowercase ");

    puts(" T ) transposed case o ) original case ");

    puts("n) next tring ");

    ans =getchar();

    ans =tolower(ans);

    eatline()  ;

    while (strchr("ulton ", ans) == NULL) {

        puts("please enter a u  l t o or n ");

        ans =tolower(getchar());

        eatline()  ;


    }

    return ans;

}

void eatline ()

{

    while (getchar() != '\n') {

        continue;


    }


}

void ToUpper(char *str)

{

    while (*str) {

        *str =toupper( *str);

        str++;


    }

}

void ToLower (char *str)

{

    while (*str) {

        *str =tolower( *str);

        str++;


    }

}

void Transpose (char *str)

{

    while (*str) {

        if (islower(*str)) {

            *str =toupper(*str );


        }

        else if (isupper(*str))

        {

            *str =tolower(*str);


        }

        str++;


    }

}

void Dummy(char * str)

{


}

void show(void(*fp) (char) , char * str)

{

    (*fp)(str);

    puts(str);


}


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352