| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 474 人关注过本帖
标题:编译不能通过,求大神指教
只看楼主 加入收藏
wu2304211
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2015-3-10
结帖率:0
收藏
已结贴  问题点数:20 回复次数:3 
编译不能通过,求大神指教
//【头文件和预定义】
#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
#include<string.h>
#define M
//【功能函数声明】
void detail();
void foreach();
void menu();
void product();
void readdata();
void seller();
void total();
void choice();
//原始数据有销售员代号、产品代号和销售额,所以定义一个全局结构体数组scrip用于保存原始数据。然后定义全局变量n保存纸条数目,定义数组s用于保存分类后的信息。
struct ss
{
    int sid;  //销售员代号
    int pid;  //产品代号
    int sn;   //销售额  
}ss[M];
 int n;        //纸条数目
 int s[4][5]={{0,0,0,0,0},{0,0,0,0,0},{0,0,0,0,0},{0,0,0,0,0}}; //用于保存员工和产品信息
//调用文件读取函数、数据初始化函数和主菜单函数
void main()  //入口函数,即主函数
{
readdata();  //读取文件数据
foreach();   //根据文件初始数据初始化便于操作的数组
menu();      //显示主菜单
}
//【文件读取函数】readdata()
//读出便条中的内容,并保存到文件结构体中
void readdata()            //从文件读取数据
{
    FILE *fp;       //定义文件指针
    if((fp=fopen("List.txt","r"))==NULL)
    {
        printf("Can't open the file!\n");
        exit(0);
    }
    else
        for(n=0;!feof(fp);n++)
        {
            fscanf(fp,"%d %d %d\n",&ss[n].sid,&ss[n].pid,&ss[n].sn);
         } //保存文件数据到结构体
    fclose(fp);
}
 void foreach()             //从纸条读取数据并分类整理
{
    int i;
    for(i=0;i<n;i++)       //遍历所有纸条
    {
        switch(ss[i].pid)     
                           //按产品分大类(例如就是case1--5),根据大类分销售员小类,累加各人各产品销售数量
            {
             case 1:
                 switch(ss[i].sid)
                 {
                  case 1:s[0][0]+=ss[i].sn;break;
                  case 2:s[1][0]+=ss[i].sn;break;
                  case 3:s[2][0]+=ss[i].sn;break;
                  case 4:s[3][0]+=ss[i].sn;break;
                 }
                  break;
             case 2:
                 switch(ss[i].sid)
                 {
                  case 1:s[0][1]+=ss[i].sn;break;
                  case 2:s[1][1]+=ss[i].sn;break;
                  case 3:s[2][1]+=ss[i].sn;break;
                  case 4:s[3][1]+=ss[i].sn;break;
                 }
                  break;
             case 3:
                 switch(ss[i].sid)
                 {
                  case 1:s[0][2]+=ss[i].sn;break;
                  case 2:s[1][2]+=ss[i].sn;break;
                  case 3:s[2][2]+=ss[i].sn;break;
                  case 4:s[3][2]+=ss[i].sn;break;
                 }
                  break;
             case 4:
                switch(ss[i].sid)
                {
                  case 1:s[0][3]+=ss[i].sn;break;
                  case 2:s[1][3]+=ss[i].sn;break;
                  case 3:s[2][3]+=ss[i].sn;break;
                  case 4:s[3][3]+=ss[i].sn;break;
                }
                 break;
             case 5:
                 switch(ss[i].sid)
                 {
                  case 1:s[0][4]+=ss[i].sn;break;
                  case 2:s[1][4]+=ss[i].sn;break;
                  case 3:s[2][4]+=ss[i].sn;break;
                  case 4:s[3][4]+=ss[i].sn;break;
                 };
                  break;   }
    }
}
/*5-1【每人每种产品销售额统计函数】detail()
计算上个月每个人每种产品的销售额*/

void detail()                   //显示销售情况
{
    int i,j;
        for(i=0;i<4;i++)        //遍历销售员
        {
        printf("\n\t\t%d号销售员销售情况:\n",i+1);
             for(j=0;j<5;j++)                              
                                //按销售员分类遍历所有产品并显示信息
              printf("\t\t%d号产品销售数量:%d\n",j+1,s[i][j]);
        }
        
    choice();
}
/*【销售员销售业绩排序函数】seller()
按销售额对销售员进行排序,输出排序结果(销售员代号)*/
void seller()
{
    int i,j,k;
    int sp[4]={0,0,0,0};
    for(i=0;i<4;i++)
        for(j=0;j<5;j++)
            sp[i]+=s[i][j];   
                                  //计算每单个销售员所有产品销售数量
        for(i=0;i<4;i++)          //比较四次,每次选出最大数
        {   k=0;                  //用于标记单轮最大数
            for(j=0;j<4;j++)
                if(sp[k]<sp[j])k=j;   //获取最大数标号
                printf("\t\t第%d名是%d号销售员!\n",i+1,k+1);sp[k]=-1;   
                                  //输出最大数和排名,将最大数标记为负
        }
    choice();
}
/*【总销售额统计函数】void product()
统计每种产品的总销售额,对这些产品按从高到低的顺序输出排序*/
 void product()         //与seller()原理一样,用于对产品进行统计
{  
    int i,j,k;
    int p[5]={0,0,0,0,0};
    for(j=0;j<5;j++)
        for(i=0;i<4;i++)
            p[j]+=s[i][j];
        for(j=0;j<5;j++)
        
      {
            k=0;
            for(i=0;i<5;i++)
                if(p[k]<p[i])k=i;
                printf("\t\t第%d名是%d号产品!\t销量为%d!\n",j+1,k+1,p[k]);p[k]=-1;
        }
    choice();
}
/*【统计报表输出函数】total()
统计每种产品的总销售额,对这些产品按从高到低的顺序输出排序结果(需输出产品代号和销售额)*/

void total()    //输出报表
{   int i,j;
    printf("\n\t销售员\t产品\t销量\n");
    for(i=0;i<4;i++)
        for(j=0;j<5;j++)
        printf("\t %d\t %d\t %d\n",i+1,j+1,s[i][j]);   
    choice();
}
/*3.3.6【公共函数】
【选择函数】choice()
选择退出系统或则返回主菜单*/
void choice()      //用于输出信息功能选择
{
int c;
printf("请选择接下来想做什么\t1>返回菜单\t2>退出系统    [ ]\b\b");
scanf("%d",&c);
if(c==1)
menu();
else
exit(0);
printf("\n");
}


搜索更多相关主题的帖子: 结构体 detail choice product include 
2015-03-10 16:32
执笔画江山
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:3
帖 子:265
专家分:1010
注 册:2015-1-13
收藏
得分:10 
#define M中  M没有值么?

授人以鱼,不如授人以渔
2015-03-10 16:55
wu2304211
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2015-3-10
收藏
得分:0 
回复 2楼 执笔画江山
编译后显示:error LNK2001: unresolved external symbol _menu
54.obj : error LNK2001: unresolved external symbol _ss
2015-03-10 17:25
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
收藏
得分:10 
這代碼肯定不是你自己寫的,否則怎麽可能寫了函數原型不給出實現代碼就敢編譯了呢,還說不知道原因的。

授人以渔,不授人以鱼。
2015-03-10 20:39
快速回复:编译不能通过,求大神指教
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.013031 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved