我是初级程序员。我想创建一个小数据库,并从中选择一些需求。它包含了很多东西的定义,所以看起来很长,但实际上不是。我认为就像有物体一样,我们在它上面添加一些东西,然后比较它们的属性。C是否适合此任务。

#include<stdio.h>

typedef struct{
    char isim;
    int adet;
    int odunc_alinma_sayisi;
    int sayfa;
    char yazar;
}kitap_ozellikleri;

kitap_ozellikleri a;
kitap_ozellikleri c;
kitap_ozellikleri y;
kitap_ozellikleri e;
kitap_ozellikleri t;
kitap_ozellikleri k;

/*int range(int maks){
    if(maks==1) {
        return 1;
    }
    int sayilar[maks];
    sayilar[maks-1] = maks;
    sayilar[maks-2] = range(maks-1);
    return sayilar[];
}
*/
    void ozellik_tanimla(){
        a.adet = 50;
        a.isim = 'a';
        a.odunc_alinma_sayisi = 30;
        a.sayfa = 280;
        a.yazar = 'e';

        c.adet = 82;
        c.isim = 'c';
        c.odunc_alinma_sayisi = 88;
        c.sayfa = 150;
        c.yazar = 'g';

        y.adet = 99;
        y.isim = 'y';
        y.odunc_alinma_sayisi = 123;
        y.sayfa = 119;
        y.yazar = 'k';

        e.adet = 53;
        e.isim = 'e';
        e.odunc_alinma_sayisi = 33;
        e.sayfa = 268;
        e.yazar = 'r';

        t.adet = 24;
        t.isim = 't';
        t.odunc_alinma_sayisi = 42;
        t.sayfa = 159;
        t.yazar = 'o';

        k.adet = 55;
        k.isim = 'k';
        k.odunc_alinma_sayisi = 110;
        k.sayfa = 296;
        k.yazar = 'o';
    }


    int main(){
        ozellik_tanimla();
        char liste[6] = {'a','c','y','e','t','k'};
        char yazar_liste[6] = {'e','g','k','r','o','o'};
        int n = 0;
        for(n=0;n<6;n++){
            int z = 0;
            for(z=0;z<6;z++){
                if(yazar_liste[n]==yazar_liste[z]){
                    kitap_ozellikleri gecici1 = yazar_liste[n]-> ;
                    kitap_ozellikleri gecici2 =  yazar_liste[z]->;
                    gecici1.sayfa += gecici2.sayfa;
                }
            }
        }

return 0;
    }

我想知道这个错误是什么,为什么会发生?

最佳答案

欢迎使用堆栈溢出。
我想我能从对问题和另一个答案的评论中看出你的意图,我相信你想要的核心循环更像是这样:

kitap_ozellikleri gecici1;
kitap_ozellikleri liste[6] = {a, c, y, e, t, k};  // no 'quotes'
char yazar_liste[6] = {'e', 'g', 'k', 'r', 'o', 'o'};
for(n=0; n<6; n++) {
    for(z=0; z<6; z++) {
        if(yazar_liste[n] == liste[z].yazar){
            gecici1.sayfa += liste[z].sayfa;
        }
    }
}

你明白我为什么把liste改成kitap_ozellikleri[]并去掉数组成员周围的''引号吗?
这将编译(在添加类似int n, z;的开销之后),但在编写时,这将统计yazar_liste[]中列出的所有作者编写的总页数。但是,它也会加倍计算作者“o”,因为该作者在yazar_liste[]中被列出了两次。
这是一个完整的版本,包含了来自各种评论的建议,打印出每个作者的计数:
代码
#include<stdio.h>

typedef struct{
    char isim;
    int adet;
    int odunc_alinma_sayisi;
    int sayfa;
    char yazar;
}kitap_ozellikleri;

kitap_ozellikleri a = { 'a', 50, 30,  280, 'e' };
kitap_ozellikleri c = { 'c', 82, 88,  150, 'g' };
kitap_ozellikleri y = { 'y', 99, 123, 119, 'k' };
kitap_ozellikleri e = { 'e', 53, 33,  268, 'r' };
kitap_ozellikleri t = { 't', 24, 42,  159, 'o' };
kitap_ozellikleri k = { 'k', 55, 110, 296, 'o' };

int main(){
    int n, z, tot;

    kitap_ozellikleri liste[6] = {a, c, y, e, t, k};  // no 'quotes'
    char yazar_liste[6] = {'e', 'g', 'k', 'r', 'o'};
    for(n=0; n<5; n++) {
        tot = 0;
        for(z=0; z<6; z++) {
            if(yazar_liste[n] == liste[z].yazar){
                tot += liste[z].sayfa;
            }
        }
        printf("total pages for sayfa %c is : %d\n", yazar_liste[n], tot);
    }

    return 0;
}

输出
total pages for sayfa e is : 280
total pages for sayfa g is : 150
total pages for sayfa k is : 119
total pages for sayfa r is : 268
total pages for sayfa o is : 455

要存储每个作者的计数(例如,供以后在程序中使用),需要引入一种跟踪多个计数器的方法。我会把这个留给你作为练习;但是当然,如果你在尝试之后有问题,请随意发布另一个单独的SO问题,详细说明你尝试了什么,你的结果,以及你预期的结果。

10-08 11:17