我是初级程序员。我想创建一个小数据库,并从中选择一些需求。它包含了很多东西的定义,所以看起来很长,但实际上不是。我认为就像有物体一样,我们在它上面添加一些东西,然后比较它们的属性。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问题,详细说明你尝试了什么,你的结果,以及你预期的结果。