C语言编程题

任务说明:
假设有40个学生被邀请来给自助餐厅的食品和服务质量打分,分数划分为1~10这10个等级(1表示最低分,10表示最高分),试编程打印统计调查结果。其中Grade代表等级,Count代表人数,Histogram表示以图形方式显示该等级的人数。程序执行结果如下:
Grade Count Histogram
1 2 **
2 3 ***
3 1 *
4 4 ****
5 2 **
6 2 **
7 2 **
8 0
9 3 ***
10 1 *

[友情提示]:

定义一个含有40个元素的一维整型数组score,用来存放每个学生打的分数。再定义一个含有11个元素的一维整型数组count,该数组的每个元素作为计数器使用,如数组元素count[1]用来记录等级(分数)为1的人数,…,count[10]用来记录等级(分数)为10的人数。实际打分人数由键盘读入。
输入要求: "%d",详见输入样例
输出要求: "Grade\tCount\tHistogram\n",详见输出样例
输入输出样例:
Input sample1:
20
1 9 1 2 4 2 2 3 4 5 5 6 6 4 7 7 9 4 9 10
Output sample1:
Grade Count Histogram
1 2 **
2 3 ***
3 1 *
4 4 ****
5 2 **
6 2 **
7 2 **
8 0
9 3 ***
10 1 *

要输入的分数太多,我懒得手数,用2位随机数代替手输入,输入函数我单独写了,你需要调用就行了,详细看备注。

#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#define stuNum 15//学生人数
#define scNum 7//模块数
typedef struct stu//定义学生数据结构
{
    int sid;//学生ID
    int sc[scNum];//对应7个模块成绩
    int sum;//总成绩
}STU;
void insertSTU(STU *stu);//输入15个学生的信息
void insertTest(STU *stu);//测试,用随机数代替输入,我懒得输入那么多成绩,你要手输,调用insertSTU替换该函数
void printfSTU(STU *stu);//按输入顺序打印15名学生7模块成绩  及  每个模块前三名的成绩
int main()
{
    STU stu[stuNum];//定义15个学生
   // int i,j,sc;
   srand(time(NULL));
    insertTest(stu);//想手动输入这里改成insertSTU(stu)
    printfSTU(stu);
    return 0;
}
void printfSTU(STU *stu)//按输入顺序打印15名学生7模块成绩  及  每个模块前三名信息 及 总分前三名信息
{
    int i,j,k,sc;
    STU *max[3],*sum[3],newstu;//max对应7个模块前3的学生结构指针 sum对应总分前3学生结构指针
    for(i=0;i<stuNum;i++)
    {
        printf("编号%02d的学生7模块成绩及总分分别为:",stu[i].sid);
        for(j=0;j<scNum;j++)
        {
            sc=stu[i].sc[j];
            printf("%02d ",sc);
        }
        printf("%d\n",stu[i].sum);
    }


    for(j=0;j<scNum;j++)
    {
        for(k=0;k<scNum;k++)
        {
            newstu.sc[k]=0;
            newstu.sum=0;
        }

        max[0]=max[1]=max[2]=&newstu;
        for(i=0;i<stuNum;i++)
        {
            if(stu[i].sc[j]>max[0]->sc[j])
                max[0]=&(stu[i]);
            else if(stu[i].sc[j]>max[1]->sc[j])
                max[1]=&(stu[i]);
            else if(stu[i].sc[j]>max[2]->sc[j])
                max[2]=&(stu[i]);
        }
        printf("模块%02d前3名分别为:编号:%02d分数:%02d  编号:%02d分数:%02d  编号:%02d分数:%02d   \n",j+1,max[0]->sid,max[0]->sc[j],max[1]->sid,max[1]->sc[j],max[2]->sid,max[2]->sc[j]);
    }

    sum[0]=sum[1]=sum[2]=&newstu;
    for(i=0;i<stuNum;i++)
    {
        if(stu[i].sum>sum[0]->sum)
            sum[0]=&(stu[i]);
        else if(stu[i].sum>sum[1]->sum)
            sum[1]=&(stu[i]);
        else if(stu[i].sum>sum[2]->sum)
            sum[2]=&(stu[i]);
    }
    printf("总分前3名分别为:编号:%02d总分:%02d  编号:%02d总分:%02d  编号:%02d总分:%02d   \n",sum[0]->sid,sum[0]->sum,sum[1]->sid,sum[1]->sum,sum[2]->sid,sum[2]->sum);

}


void insertSTU(STU *stu)//输入15个学生的信息
{
    int i,j,sc;
    for(i=0;i<stuNum;i++)
    {
        stu[i].sid=i+1;
        stu[i].sum=0;
        printf("输入编号%d的学生的7个模块成绩:",i+1);
        for(j=0;j<scNum;j++)
        {
            //scanf("%d",&sc);// 我懒得输入那么多成绩,就用随机数代替,你要输入把这句恢复
            sc=(int)(rand()%100);//用随即2位数代替输入,不需要就注释掉
            stu[i].sc[j]=sc;
            stu[i].sum=stu[i].sum+sc;
        }
    }
}
void insertTest(STU *stu)//测试用代替输入
{
    int i,j,sc;
    for(i=0;i<stuNum;i++)
    {
        stu[i].sid=i+1;
        stu[i].sum=0;
        for(j=0;j<scNum;j++)
        {
            sc=(int)(rand()%100);
            stu[i].sc[j]=sc;
            stu[i].sum=stu[i].sum+sc;
        }
    }
}

温馨提示:答案为网友推荐,仅供参考
第1个回答  2014-06-29

#include <stdio.h>
#include <math.h>
void main()
{
    char  ip[33]="";
    int i=31,j,k=3,sum[4]={0,0,0,0};
  puts("请输入完整二进制ip地址");
 gets(ip );
 puts("转化后为:");
     while(i>=0)
  {  
         j=0;
        while(j<8)
  {            
                sum[k]+=(ip[i]-48)*pow(2,j);    
                i--;              
                j++;
  }
                k--;
}
printf("%d:%d:%d:%d\n",sum[0],sum[1],sum[2],sum[3]);
}

 

#include <stdio.h>
#include <math.h>
void main()
{
  //比如ip为:11111111 11111111 11111111 11111111  //按照8421法转化为16进制
int ip=0xffffffff; //
printf("%d.%d.%d.%d\n",(ip >> 24)&0xff,(ip >> 16)&0xff,(ip>>8)&0xff,ip&0xff);
}

 

第2个回答  2010-05-23

以下的代码就可以实现你的所有要求了(但是是用C++编的,不知道楼主是要C++还是C的):

#include<iostream>

#include<fstream>

using namespace std;

void show_original_files(ifstream& out);

void add_message(ifstream& in,ofstream& add,int& n);

void show_changed_files(ifstream& in,int n);

int main()

{

 int n=0;

 ifstream fin;

 ofstream fout;

 cout<<"加载message.txt文件。。。\n";

 fout.open("message.txt",ios::app);

 if(fout.fail())

 {

  cout<<"文件加载错误!";

  exit(1);

 }

 fin.open("message.txt");

 if(fin.fail())

 {

  cout<<"文件加载错误!";

  exit(1);

 }

 

 show_original_files(fin);

 add_message(fin,fout,n);

 fout.close();

 show_changed_files(fin,n);

 fin.close();

 return 0;

void show_original_files(ifstream& in)

{

 char ch;

 in.get(ch);

 if(in.eof())

  cout<<"\n原文件内容为空。";

 else

 {

  cout<<"\n原文件内容为:";

  while(!in.eof())

  {

   cout<<ch;

   in.get(ch);

  }

 }

 cout<<endl;

}

void add_message(ifstream& in,ofstream& add,int& n)

{

 char ch;

 cout<<"\n输入你要添加到文件的内容:\n";

 cin.get(ch);

 while(ch!='\n')

 {

  add<<ch;

  n++;

  cin.get(ch);

 }

}

void show_changed_files(ifstream& in,int n)

{

 char ch;

 int i;

 cout<<"\n你想输出文件的哪部分内容?(1.整个文件;2.刚才输入的信息)\n"

  <<"请选择:";

 cin>>i;

 

 if(i==1)

 {

  in.clear();

  in.seekg(0);

  cout<<"\n添加后整个文件内容为:";

  in.get(ch);

  while(!in.eof())

  {

   cout<<ch;

   in.get(ch);

  }

  cout<<endl;

 }

 else if(i==2)

 {

  in.clear();

  cout<<"\n你刚才输入的信息为:";

  in.get(ch);

  while(!in.eof())

  {

   cout<<ch;

   in.get(ch);

  }

  cout<<endl;

 }

}

运行结果

第3个回答  2018-03-17

// seqstack.h
#define MAX 100

typedef struct {
datatype data[MAX];
int top;
}SeqStack;

SeqStack *initStack() {
SeqStack *head = (SeqStack *)malloc(sizeof(SeqStack));
head->top = 0;
memset(head,0,MAX*sizeof(datatype));
return head;
}

int isEmpty(SeqStack *head) {
return head->top == 0;
}

int isFull(SeqStack *head) {
return head->top == MAX;
}

int Push(SeqStack *head, datatype e) {
if(isFull(head)) return 0;
head->data[head->top] = e;
++head->top;
return 1;
}

int Pop(SeqStack *head, datatype *e) {
if(isEmpty(head)) return 0;
--head->top;
*e = head->data[head->top];
return 1;
}


#include <stdio.h>
#include <malloc.h>
#include <memory.h>
typedef char datatype;//栈元素数据类型
#include "seqstack.h"

int main(void) {
char s[100],op,i;
SeqStack *stck = initStack();
printf("Input a string : ");
scanf("%s",s);
for(i = 0; s[i]; ++i) {
if(s[i] == '(') Push(stck,s[i]);
if(s[i] == '[') Push(stck,s[i]);
if(s[i] == '{') Push(stck,s[i]);
if(s[i] == ')') {
Pop(stck,&op);
if(op != '(') {
printf("没有找到与')'匹配的'('。\n");
return 1;
}
}
if(s[i] == ']') {
Pop(stck,&op);
if(op != '[') {
printf("没有找到与']'匹配的'['。\n");
return 1;
}
}
if(s[i] == '}') {
Pop(stck,&op);
if(op != '{') {
printf("没有找到与'}'匹配的'{'。\n");
return 1;
}
}
}
printf("完美匹配!\n");
return 0;
}

第4个回答  2017-10-18
#include <stdio.h>
int main()
{
double j,s=1,n=1;
int a=0,b=1;
printf("请输入精度:");
scanf("%lf",&j);
while(n>=j)
{
a+=1;
b+=2;
n=n*a/b;
s=s+n;
}
printf("π≈%lf\n",2*s);
}

不过输入0.001的输出和你的例子不一样。仅供参考。

你的代码修改如下:

#include <stdio.h>
int main()
{
float pi,t,s,i,j;
i=1;s=1;t=0;pi=1;
scanf("%f",&t);
while(s>=t)
{
s=s*i/(2*i+1);
pi=pi+s;
i=i+1;
}
printf("%7f",pi*2);

return 0;
}

pi1和pi2没有实际作用。

相似回答