高分!向您跪下了。C语言程序考试。求高手。急急急★★★★

作者&投稿:道哗 (若有异议请与网页底部的电邮联系)
C语言程序设计 ,高分求 答案!!!~

字数受限,只能打这多了或看看这个http://wenku.baidu.com/view/92d3d138376baf1ffc4fad1a.html#include "stdio.h" #include "stdlib.h" #include "string.h" #include "conio.h" #include "mem.h" #include "ctype.h" /#include "alloc.h" #define N 3 typedef struct z1
{
char no[11];
char name[15];
int score[N];
float sum;
float average;
int order;
struct z1 *next;
}STUDENT;

STUDENT *init();
STUDENT *create();
STUDENT *delete(STUDENT *h);
void print(STUDENT *h); /* 显示所有记录*/
void search(STUDENT *h); /*查找*/
void save(STUDENT *h); /*保存*/
STUDENT *load(); /*读入记录*/
void computer(STUDENT *h); /*计算总分和均分*/
STUDENT *insert(STUDENT *h); /*插入记录*/
void append(); /*追加记录*/
void copy(); /*复制文件*/
STUDENT *sort(STUDENT *h); /*排序*/
STUDENT *index(STUDENT *h); /*索引*/
void total(STUDENT *h); /*分类合计*/
int menu_select(); /*菜单函数*/
/******主函数开始*******/
main()
{
int i;
STUDENT *head; /*链表定义头指针*/
head=init(); /*初始化链表*/
clrscr(); /*清屏*/
for(;;) /*无限循环*/
{
switch(menu_select()) /*调用主菜单函数,返回值整数作开关语句的条件*/
{ /*值不同,执行的函数不同,break 不能省略*/
case 0:head=init();break;
case 1:head=create();break;
case 2:head=delete(head);break;
case 3:print(head);break; /*显示全部记录*/
case 4:search(head);break; /*查找记录*/
case 5:save(head);break; /*保存文件*/
case 6:head=load(); break; /*读文件*/
case 7:computer(head);break; /*计算总分和均分*/
case 8:head=insert(head); break; /*插入记录*/
case 9:copy();break; /*复制文件*/
case 10:head=sort(head);break; /*排序*/
case 11:append();break; /*追加记录*/
case 12:head=index(head);break; /*索引*/
case 13:total(head);break; /*分类合计*/
case 14:exit(0); /*如菜单返回值为14程序结束*/
}
}
}
/*菜单函数,返回值为整数*/
menu_select()
{
char *menu[]={"***************MENU***************", /*定义菜单字符串数组*/
" 0. init list", /*初始化*/
" 1. Enter list", /*输入记录*/
" 2. Delete a record from list", /*从表中删除记录*/
" 3. print list ", /*显示单链表中所有记录*/
" 4. Search record on name", /*按照姓名查找记录*/
" 5. Save the file", /*将单链表中记录保存到文件中*/
" 6. Load the file", /*从文件中读入记录*/
" 7. compute the score", /*计算所有学生的总分和均分*/
" 8. insert record to list ", /*插入记录到表中*/
" 9. copy the file to new file", /*复制文件*/
" 10. sort to make new file", /*排序*/
" 11. append record to file", /*追加记录到文件中*/
" 12. index on nomber", /*索引*/
" 13. total on nomber", /*分类合计*/
" 14. Quit"}; /*退出*/
char s[3]; /*以字符形式保存选择号*/
int c,i; /*定义整形变量*/
gotoxy(1,25); /*移动光标*/
printf("press any key enter menu......
"); /*压任一键进入主菜单*/
getch(); /*输入任一键*/
clrscr(); /*清屏幕*/
gotoxy(1,1); /*移动光标*/
textcolor(YELLOW); /*设置文本显示颜色为黄色*/
textbackground(BLUE); /*设置背景颜色为蓝色*/
gotoxy(10,2); /*移动光标*/
putch(0xc9); /*输出左上角边框┏*/
for(i=1;i<44;i++)
putch(0xcd); /*输出上边框水平线*/
putch(0xbb); /*输出右上角边框 ┓*/
for(i=3;i<20;i++)
{
gotoxy(10,i);putch(0xba); /*输出左垂直线*/
gotoxy(54,i);putch(0xba);
} /*输出右垂直线*/
gotoxy(10,20);putch(0xc8); /*输出左上角边框┗*/
for(i=1;i<44;i++)
putch(0xcd); /*输出下边框水平线*/
putch(0xbc); /*输出右下角边框┛*/
window(11,3,53,19); /* 制作显示菜单的窗口,大小根据菜单条数设计*/
clrscr(); /*清屏*/
for(i=0;i<16;i++) /*输出主菜单数组*/
{
gotoxy(10,i+1);
cprintf("%s",menu[i]);
}
textbackground(BLACK); /*设置背景颜色为黑色*/
window(1,1,80,25); /*恢复原窗口大小*/
gotoxy(10,21); /*移动光标*/
do{
printf("
Enter you choice(0~14):"); /*在菜单窗口外显示提示信息*/
scanf("%s",s); /*输入选择项*/
c=atoi(s); /*将输入的字符串转化为整形数*/
}while(c14); /*选择项不在0~14之间重输*/
return c; /*返回选择项,主程序根据该数调用相应的函数*/
}
STUDENT *init()
{
return NULL;
}

/*创建链表*/
STUDENT *create()
{
int i; int s;
STUDENT *h=NULL,*info; /* STUDENT指向结构体的指针*/
for(;;)
{
info=(STUDENT *)malloc(sizeof(STUDENT)); /*申请空间*/
if(!info) /*如果指针info为空*/
{
printf("
out of memory"); /*输出内存溢出*/
return NULL; /*返回空指针*/
}
inputs("enter no:",info->no,11); /*输入学号并校验*/
if(info->no[0]=='@') break; /*如果学号首字符为@则结束输入*/
inputs("enter name:",info->name,15); /*输入姓名,并进行校验*/
printf("please input %d score
",N); /*提示开始输入成绩*/
s=0; /*计算每个学生的总分,初值为0*/
for(i=0;i<N;i++) /*N门课程循环N次*/
{
do{
printf("score%d:",i+1); /*提示输入第几门课程*/
scanf("%d",&info->score[i]);
if(info->score[i]>100||info->score[i]<0)
printf("bad data,repeat input
");
}while(info->score[i]>100||info->score[i]<0);
s=s+info->score[i];
}
info->sum=s;
info->average=(float)s/N;
info->order=0;
info->next=h;
h=info; }
return(h); /*返回头指针*/
}
/*输入字符串,并进行长度验证*/
inputs(char *prompt, char *s, int count)
{
char p[255];
do{
printf(prompt); /*显示提示信息*/
scanf("%s",p); if(strlen(p)>count)printf("
too long!
"); }while(strlen(p)>count);
strcpy(s,p); }
void print(STUDENT *h)
{
int i=0; /* 统计记录条数*/
STUDENT *p; /*移动指针*/
clrscr(); /*清屏*/
p=h; /*初值为头指针*/
printf("


****************************STUDENT********************************
");
printf("|rec|nO | name | sc1| sc2| sc3| sum | ave |order|
");
printf("|---|----------|---------------|----|----|----|--------|-------|-----|
");
while(p!=NULL)
{
i++;
printf("|%3d |%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |
", i, p->no,p->name,p->score[0],p->score[1],
p->score[2],p->sum,p->average,p->order);
p=p->next;
}
printf("**********************************end*********************************
");
}
/*删除记录*/
STUDENT *delete(STUDENT *h)
{
STUDENT *p,*q; /*p为查找到要删除的结点指针,q为其前驱指针*/
char s[11]; /*存放学号*/
clrscr(); /*清屏*/
printf("please deleted no
"); /*显示提示信息*/
scanf("%s",s); /*输入要删除记录的学号*/
q=p=h; /*给q和p赋初值头指针*/
while(strcmp(p->no,s)&&p!=NULL) /*当记录的学号不是要找的,或指针不为空时*/
{
q=p; /*将p指针值赋给q作为p的前驱指针*/
p=p->next; /*将p指针指向下一条记录*/
}
if(p==NULL) /*如果p为空,说明链表中没有该结点*/
printf("
list no %s student
",s);
else /*p不为空,显示找到的记录信息*/
{
printf("*****************************have found***************************
");
printf("|no | name | sc1| sc2| sc3| sum | ave |order|
");
printf("|----------|---------------|----|----|----|--------|-------|-----|
");
printf("|%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |
", p->no,
p->name,p->score[0],p->score[1],p->score[2],p->sum,
p->average,p->order);
printf("********************************end*******************************
");
getch(); /*压任一键后,开始删除*/
if(p==h) /*如果p==h,说明被删结点是头结点*/
h=p->next; /*修改头指针指向下一条记录*/
else
q->next=p->next; /*不是头指针,将p的后继结点作为q的后继结点*/
free(p); /*释放p所指结点空间*/
printf("
have deleted No %s student
",s);
printf("Don't forget save
");/*提示删除后不要忘记保存文件*/
}
return(h); /*返回头指针*/
}
/*查找记录*/
void search(STUDENT *h)
{
STUDENT *p; char s[15]; clrscr();
printf("please enter name for search
");
scanf("%s",s); /*输入姓名*/
p=h; /*将头指针赋给p*/
while(strcmp(p->name,s)&&p!=NULL) /*当记录的姓名不是要找的,或指针不为空时*/
p=p->next; /*移动指针,指向下一结点*/
if(p==NULL) /*如果指针为空*/
printf("
list no %s student
",s); /*显示没有该学生*/
else /*显示找到的记录信息*/
{
printf("

*****************************havefound***************************
");
printf("|nO | name | sc1| sc2| sc3| sum | ave |order|
");
printf("|----------|---------------|----|----|----|--------|-------|-----|
");
printf("|%-10s|%-15s|%4d|%4d|%4d| %4.2f | %4.2f | %3d |
", p->no,
p->name,p->score[0],p->score[1],p->score[2],p->sum,p->average,p->order);
printf("********************************end*******************************
");
}
}
/*插入记录*/
STUDENT *insert(STUDENT *h)
{
STUDENT *p,*q,*info; /*p指向插入位置,q是其前驱,info指新插入记录*/
char s[11]; /*保存插入点位置的学号*/
int s1,i;
printf("please enter location before the no
");
scanf("%s",s); /*输入插入点学号*/
printf("
please new record
"); /*提示输入记录信息*/
info=(STUDENT *)malloc(sizeof(STUDENT)); /*申请空间*/
if(!info)
{
printf("
out of memory"); /*如没有申请到,内存溢出*/
return NULL; /*返回空指针*/
}
inputs("enter no:",info->no,11); /*输入学号*/
inputs("enter name:",info->name,15); /*输入姓名*/
printf("please input %d score
",N); /*提示输入分数*/
s1=0; /*保存新记录的总分,初值为0*/
for(i=0;i<N;i++) /*N门课程循环N次输入成绩*/
{
do{ /*对数据进行验证,保证在0~100之间*/
printf("score%d:",i+1);
scanf("%d",&info->score[i]);
if(info->score[i]>100||info->score[i]<0)
printf("bad data,repeat input
");
}while(info->score[i]>100||info->score[i]<0);
s1=s1+info->score[i]; /*计算总分*/
}
info->sum=s1; /*将总分存入新记录中*/
info->average=(float)s1/N; /*计算均分*/
info->order=0; /*名次赋值0*/
info->next=NULL; /*设后继指针为空*/
p=h; /*将指针赋值给p*/
q=h; /*将指针赋值给q*/
while(strcmp(p->no,s)&&p!=NULL) /*查找插入位置*/
{
q=p; /*保存指针p,作为下一个p的前驱*/
p=p->next; /*将指针p后移*/
}
if(p==NULL) /*如果p指针为空,说明没有指定结点*/
if(p==h) /*同时p等于h,说明链表为空*/
h=info; /*新记录则为头结点*/
else
q->next=info; else
if(p==h) {
info->next=p; h=info; }
else
{
info->next=p; q->next=info;
}
printf("
----have inserted %s student----
",info->name); printf("---Don't forget save---
"); /*提示存盘*/
return(h); /*返回头指针*/
}
/*保存数据到文件*/
void save(STUDENT *h)
{
FILE *fp; /*定义指向文件的指针*/
STUDENT *p; /* 定义移动指针*/
char outfile[10]; /*保存输出文件名*/
printf("Enter outfile name,for example c:\\f1\e.txt:
"); /*提示文件名格式信息*/
scanf("%s",outfile);
if((fp=fopen(outfile,"wb"))==NULL) /*为输出打开一个二进制文件,如没有则建立*/
{
printf("can not open file
");
exit(1);
}
printf("
Saving file......
"); /*打开文件,提示正在保存*/
p=h; /*移动指针从头指针开始*/
while(p!=NULL) /*如p不为空*/
{
fwrite(p,sizeof(STUDENT),1,fp);/*写入一条记录*/
p=p->next; /*指针后移*/
}
fclose(fp); /*关闭文件*/
printf("-----save success!!-----
"); /*显示保存成功*/
}
/* 从文件读数据*/
STUDENT *load()
{
STUDENT *p,*q,*h=NULL; /*定义记录指针变量*/
FILE *fp; /* 定义指向文件的指针*/
char infile[10]; /*保存文件名*/
printf("Enter infile name,for example c:\\f1\e.txt:
"); scanf("%s",infile); /*输入文件名*/
if((fp=fopen(infile,"rb"))==NULL) /*打开一个二进制文件,为读方式*/
{
printf("can not open file
"); /*如不能打开,则结束程序*/
exit(1);
}
printf("
-----Loading file!-----
");
p=(STUDENT *)malloc(sizeof(STUDENT)); /*申请空间*/
if(!p)
{
printf("out of memory!
"); /*如没有申请到,则内存溢出*/
return h; /*返回空头指针*/
}
h=p; /*申请到空间,将其作为头指针*/
while(!feof(fp)) /*循环读数据直到文件尾结束*/
{
if(1!=fread(p,sizeof(STUDENT),1,fp))
break; /*如果没读到数据,跳出循环*/
p->next=(STUDENT *)malloc(sizeof(STUDENT)); /*为下一个结点申请空间*/
if(!p->next)
{
printf("out of memory!
"); return h;
}
q=p; p=p->next; }
q->next=NULL; /*最后一个结点的后继指针为空*/
fclose(fp); /*关闭文件*/
printf("---You have success read data from file!!!---
");
return h; /*返回头指针*/
}
/*追加记录到文件*/
void append()
{
FILE *fp; /*定义指向文件的指针*/
STUDENT *info; /*新记录指针*/
int s1,i;
char infile[10]; /*保存文件名*/
printf("
please new record
");
info=(STUDENT *)malloc(sizeof(STUDENT)); /*申请空间*/
if(!info)
{
printf("
out of memory"); /*没有申请到,内存溢出本函数结束*/
return ;
}
inputs("enter no:",info->no,11); /*调用inputs输入学号*/
inputs("enter name:",info->name,15); /*调用inputs输入姓名*/
printf("please input %d score
",N); /*提示输入成绩*/
s1=0;
for(i=0;i<N;i++)
{
do{
printf("score%d:",i+1);
scanf("%d",&info->score[i]); /*输入成绩*/
if(info->score[i]>100||info->score[i]<0)printf("bad data,repeat input
");
}while(info->score[i]>100||info->score[i]<0); /*成绩数据验证*/
s1=s1+info->score[i]; /*求总分*/
}
info->sum=s1; /*保存总分*/
info->average=(float)s1/N; /*求均分*/
info->order=0; /*名次初始值为0*/
info->next=NULL; /*将新记录后继指针赋值为空*/
printf("Enter infile name,for example c:\\f1\e.txt:
"); scanf("%s",infile); /*输入文件名*/
if((fp=fopen(infile,"ab"))==NULL) /*向二进制文件尾增加数据方式打开文件*/
{
printf("can not open file
"); /*显示不能打开*/
exit(1); /*退出程序*/
}
printf("
-----Appending record!-----
");
if(1!=fwrite(info,sizeof(STUDENT),1,fp)) /*写文件操作*/
{
printf("-----file write error!-----
");
return; /*返回*/
}
printf("-----append sucess!!----
");
fclose(fp); /*关闭文件*/
}
/*文件拷贝*/
void copy()
{
char outfile[10],infile[10];
FILE *sfp,*tfp; /*源和目标文件指针*/
STUDENT *p=NULL; /*移动指针*/
clrscr(); /*清屏*/
printf("Enter infile name,for example c:\\f1\e.txt:
");
scanf("%s",infile); /*输入源文件名*/
if((sfp=fopen(infile,"rb"))==NULL) /*二进制读方式打开源文件*/
{
printf("can not open input file
");
exit(0);
}
printf("Enter outfile name,for example c:\\f1\e.txt:
"); /*提示输入目标文件名*/
scanf("%s",outfile); /*输入目标文件名*/
if((tfp=fopen(outfile,"wb"))==NULL) /*二进制写方式打开目标文件*/
{
printf("can not open output file
");
exit(0);
}
while(!feof(sfp)) /*读文件直到文件尾*/
{
if(1!=fread(p,sizeof(STUDENT),1,sfp))
break; /*块读*/
fwrite(p,sizeof(STUDENT),1,tfp); /*块写*/
}
fclose(sfp); /*关闭源文件*/
fclose(tfp); /*关闭目标文件*/
printf("you have success copy file!!!
"); /*显示成功拷贝*/
}
/*排序*/
STUDENT *sort(STUDENT *h)
{
int i=0; /*保存名次*/
STUDENT *p,*q,*t,*h1; /*定义临时指针*/
h1=h->next; /*将原表的头指针所指的下一个结点作头指针*/
h->next=NULL; /*第一个结点为新表的头结点*/
while(h1!=NULL) /*当原表不为空时,进行排序*/
{
t=h1; /*取原表的头结点*/
h1=h1->next; /*原表头结点指针后移*/
p=h; /*设定移动指针p,从头指针开始*/
q=h; /*设定移动指针q做为p的前驱,初值为头指针*/
while(t->sumsum&&p!=NULL) /*作总分比较*/
{
q=p; /*待排序点值小,则新表指针后移*/
p=p->next;
}
if(p==q) /*p==q,说明待排序点值大,应排在首位*/
{
t->next=p; /*待排序点的后继为p*/
h=t; /*新头结点为待排序点*/
}
else /*待排序点应插入在中间某个位置q和p之间,如p为空则是尾部*/
{
t->next=p; /*t的后继是p*/
q->next=t; /*q的后继是t*/
}
}
p=h; /*已排好序的头指针赋给p,准备填写名次*/
while(p!=NULL) /*当p不为空时,进行下列操作*/
{
i++; /*结点序号*/
p->order=i; /*将名次赋值*/
p=p->next; /*指针后移*/
}
printf("sort sucess!!!
"); /*排序成功*/
return h; /*返回头指针*/
}
/*计算总分和均值*/
void computer(STUDENT *h)
{
STUDENT *p; /*定义移动指针*/
int i=0; /*保存记录条数初值为0*/
long s=0; /*总分初值为0*/
float average=0; /*均分初值为0*/
p=h; /*从头指针开始*/
while(p!=NULL) /*当p不为空时处理*/
{
s+=p->sum; /*累加总分*/
i++; /*统计记录条数*/
p=p->next; /*指针后移*/
}
average=(float)s/i;/* 求均分,均分为浮点数,总分为整数,所以做类型转换*/
printf("
--All students sum score is:%ld average is %5.2f
",s,average);
}
/*索引*/
STUDENT *index(STUDENT *h)
{
STUDENT *p,*q,*t,*h1; /*定义临时指针*/
h1=h->next; /*将原表的头指针所指的下一个结点作头指针*/
h->next=NULL; /*第一个结点为新表的头结点*/
while(h1!=NULL) /*当原表不为空时,进行排序*/
{
t=h1; /*取原表的头结点*/
h1=h1->next; /*原表头结点指针后移*/
p=h; /*设定移动指针p,从头指针开始*/
q=h; /*设定移动指针q做为p的前驱,初值为头指针*/
while(strcmp(t->no,p->no)>0&&p!=NULL) /*作学号比较*/
{
q=p; p=p->next;
}
if(p==q) /*p==q, {
t->next=p; h=t; }
else {
t->next=p; /*t的后继是p*/
q->next=t; /*q的后继是t*/
}
}
printf("index sucess!!!
"); /*索引排序成功*/
return h; /*返回头指针*/
}
/*分类合计*/
void total(STUDENT *h)
{
STUDENT *p,*q; /*定义临时指针变量*/
char sno[9],qno[9],*ptr; /*保存班级号的*/
float s1,ave; /*保存总分和均分*/
int i; clrscr(); /*清屏*/
printf("

*******************Total*****************
");
printf("---class---------sum--------------average----
");
p=h; while(p!=NULL)
{
memcpy(sno,p->no,8); /*从学号中取出班级号*/
sno[8]='\0'; /*做字符串结束标记*/
q=p->next; /*将指针指向待比较的记录*/
s1=p->sum; /*当前班级的总分初值为该班级的第一条记录总分*/
ave=p->average; /*当前班级的均分初值为该班级的第一条记录均分*/
i=1; /*统计当前班级人数*/
while(q!=NULL) /*内循环开始*/
{
memcpy(qno,q->no,8); /*读取班级号*/
qno[8]='\0'; /*做字符串结束标记*/
if(strcmp(qno,sno)==0) /*比较班级号*/
{
s1+=q->sum; /*累加总分*/
ave+=q->average; /*累加均分*/
i++; /*累加班级人数*/
q=q->next; /*指针指向下一条记录*/
}
else
break; }
printf("%s %10.2f %5.2f
",sno,s1,ave/i);
if(q==NULL)
break; else
p=q; }
printf("---------------------------------------------
");
}


/*
变量说明:
n:n个学生
m:m个评委
score[100][20]:最多可存20个评委对100位选手的打分
num[100]:保存选手序号
sum[100]:保存每位选手的平均分
ping[20]:保存对评委打分能力的指数 用它的评分减去各先手平均分之差的绝对值。
pingnum[20]:保存评委的序号
lower:保存最低分
*/

#include
#include

void main()
{
int i,j,n,m,sum[100],ping[20],pingnum[20],num[100],p=0;
int score[100][20],lower,temp=0;
printf("enter n m:");
scanf("%d",&n);
scanf("%d",&m);

for(i=0;i<m;i++) /*对评委指数和评委序号进行初始化*/
{
ping[i]=0;
pingnum[i]=i+1;
}

for(i=0;i<n;i++) /*对选手序号进行初始化*/
num[i]=i+1;

for(i=0;i<n;i++)
{
printf("enter player %d score:
",i+1); /*输入每位选手的m位评委的打分*/
for(j=0;j<m;j++)
{
printf("enter ping wei %d score:",j+1);
scanf("%d",&score[i][j]);
if(lower>score[i][j])
{
lower=score[i][j]; /*保存最低分*/
}
sum[i]+=score[i][j]; /*计算每位选手的总分*/
}
sum[i]-=lower; /*减去最低分*/
sum[i]/=(m-1); /*计算选手的平均得分*/
for(j=0;j<m;j++)
{
ping[j]+=abs(score[i][j]-sum[i]);/*保存评委的打分指数*/
}
}

for(i=0;i<n;i++) /*根据选手的平均分进行排序*/
{p=i;
for(j=i+1;j<n;j++)
if(sum[p]<sum[j])
p=j;
if(p!=i)
{
temp=sum[p];
sum[p]=sum[i];
sum[i]=temp;

temp=num[p];
num[p]=num[i];
num[i]=temp;
}
}

for(i=0;i<m;i++) /*根据评委打分指数对评委进行排序*/
{p=i;
for(j=i+1;j<m;j++)
if(sum[p]<sum[j])
p=j;
if(p!=i)
{
temp=ping[p];
ping[p]=ping[i];
ping[i]=temp;

temp=pingnum[p];
pingnum[p]=pingnum[i];
pingnum[i]=temp;
}
}

printf("print player list:
");
for(i=0;i<n;i++)
{
printf("%d %d
",i+1,num[i]);
}
printf("
print ping wei list:
");
for(i=0;i<m;i++)
{
printf("%d %d
",i+1,pingnum[i]);
}

}

给你写前三个吧:
1.
#include <stdio.h>
/* 计算个人所得税 */
int main(){
float sr,se,d1,d2,d3,d4,d5,d6,d7,d8,d9;
d1=500*0.05;
d2=d1+1500*0.1;
d3=d2+3000*0.15;
d4=d3+15000*0.20;
d5=d4+20000*0.25;
d6=d5+20000*0.30;
d7=d6+20000*0.35;
d8=d7+20000*0.40;

scanf("%f",&sr);
sr-=2000; /* 超过2000部分,即应纳税部分 */
if(sr<=0) /* 没有超过2000,不纳税 */
se=0;
else if(sr<500) /* 超过部分<500 */
se=0.05*sr;
else if(sr<2000) /* 超过部分500~2000 */
se=d1+0.1*(sr-500);
else if(sr<5000) /* 超过部分2000~5000 */
se=d2+0.15*(sr-2000);
else if(sr<20000) /* 超过部分5000~20000 */
se=d3+0.20*(sr-5000);
else if(sr<40000) /* 超过部分20000~40000 */
se=d4+0.25*(sr-20000);
else if(sr<60000) /* 超过部分40000~60000 */
se=d5+0.30*(sr-40000);
else if(sr<80000) /* 超过部分60000~80000 */
se=d6+0.35*(sr-60000);
else if(sr<100000) /* 超过部分80000~100000 */
se=d7+0.40*(sr-80000);
else /* 超过部分>=100000 */
se=d8+0.45*(sr-100000);
printf("%.2f, %.2f\n",sr+2000,se);
return 0;
}
2.
#include <stdio.h>

int properfactor_sum(int n){
int r=1,i;
for(i=2; i<n; i++)
if(n%i==0)
r+=i;
return r;
}

int main(){
int i,n,m;
for(i=1000; i<=9999; i++){
n=properfactor_sum(i);
m=properfactor_sum(n);
if(m==i && i<n)
printf("%d, %d\n",i,n);
}
return 0;
}

3.
#include <stdio.h>
#include <math.h>
int isprime(long n) //判断n是否为素数
{
int i,f=1,k=abs(n);
for(i=2;f==1 && i<=k;i++)
f=n%i;
return f;
}

int main(){
int i;
for(i=100; i<200; i++){
if(isprime(i) && isprime(i+2))
printf("%d, %d\n",i,i+2);
}

return 0;
}

第一题 用swith语句 分情况讨论;
2、定义一个长为1000的数组,用双for循环,用数组存放期下标的真因数之和,再写个for 用下标和数组的值对比,相等的话就是了;
3、还是用for 先判断单签数字是不是质数,是的话他加2再看是不是质数,是的话就找到了 不是的话继续
4、还是建个数组,必须确保每两个100元之间必须至少有一个50元的。先判断有没有 没有的话换位置。


我喜欢的女孩老是叫我跪下怎么办
我喜欢的女孩老是叫我跪下怎么办我初三,因为在喜欢的女孩面前做错事了她就叫我每天和她去特定的地点给给她跪半个钟头一直跪到学期结束。说实话我也愿意跪在她面前,但是她老是穿着凉... 我喜欢的女孩老是叫我跪下怎么办我初三,因为在喜欢的女孩面前做错事了她就叫我每天和她去特定的地点给给她跪半个钟头...

下面几题怎么写 ,跪下来求你们了,快点这是作业
2、(1)由于 200\/3=66 余 2 ,而 200\/6=33 余 2,这说明 200 个数每列三个,共有 66 列还余 2 个 。而每个周期有 6 个数 ,因此最后的 2 个数是向下排列的 ,所以 A 组有 67 个数,最后一个是 199 ,B 组有 67 个数,最后一个是 200 ,C 组有 66 个数,最后一个...

好心人求求你了百草枯解药求求你了给你全家跪下了
4、 对症和支持治疗,特别应注意处理好ARDS、肝坏死和急性肾功能衰竭等威胁生命的毒效应。5、 氧疗应十分小心,决不可用高浓度氧,否则弊大于利,一般应限制吸氧,只有在血中氧分压低于5.3kPa(40mmHg)时,才可用浓度>21%的氧吸人。6、迟发肺纤维化病例,国外曾用肺移植治疗。打120求救 ...

哥哥嫂嫂 姐夫姐姐你们快点来哦 弟弟跪下 了
反过来说,只要是 815\/T 的板子,就可以上所有的 CII,CIII,PIII 。注:815\/T 芯片组是370针脚CPU的终结者,只要保证你的主板是带 T 的,就可以上 P4 前的所有CPU。另外,815 芯片组最大只支持总容量为512M 的内存,包括815\/T 。识别一块板子是否支持图拉丁,最简单的办法就是看板子上的编号...

电视剧风云雄霸天下的主题曲哪里下载?我QQ308507753,给你们跪下了。
风云__江得胜 http:\/\/202.108.23.172\/m?ct=134217728&tn=baidusg,风云%20%20片头曲%20江得胜&word=wma,http:\/\/www.333mp3.com\/uuauth\/4\/1783\/aGppaTU$.wma,,[%B7%E7%D4%C6+%BD%AD%B5%C3%CA%A4]&lm=16777216 http:\/\/202.108.23.172\/m?ct=134217728&tn=baidusg,江得胜%20...

太c了大腿什么意思
“太C了大腿”这句话是不文明的,含有侮辱意味,通常用来形容某人或某团队在某些方面非常出色或表现出色。"C"在这里是一个缩写,可以表示“酷”、“才华横溢”、“强大”等意思,而“大腿”则是一种比喻,表示某人在某个领域或方面非常优秀,能够带领或帮助他人取得成功。总的来说,“太C了大腿”是...

诸葛亮借东风阅读,给你跪下哩
诸葛亮’”指当代的气象科技人员。B.现在,人工影响天气已取得可喜的成果,几千年来人们呼风唤雨的神话早已成为了现实。C.人们对改变大范围天气或气候的办法,提出了一些设想并开始付诸行动。D.到下世纪,我们人类一定可以改变大范围的天气或气候,进而改变整个地球的气候。感觉是初中语文阅读理解 ...

学霸们,给个答案,我跪下求你了
C

A君和C君.我该怎么选择
我觉得呢,恋爱一场,总不能搞个不明不白的结局,问问A君为什么跟你分手。 看得出来,你喜欢A君很大程度是因为他学习好吧。 但在我一个旁观者眼里看,这个A君对感情比较没交代啊,交往的事,怎么能不说清楚,说分就分呢,他怎么不考虑一下你的感受啊?感情的事,还是要跟着感觉走,尤其你现在还...

男朋友被我捉奸在床,他跪下来求我,还割腕,我是否原谅他?
原谅他你就有问题了,首先他劈腿,这个已经是不可原谅的了,就算他再后悔,有一就有二,而且现在还只是男女朋友,如果你是他老婆他才不管呢,反正已经到手了。其次,你看过“不要和陌生人说话”吗,里面的男主角也是号称很爱她老婆的,是因为吃醋才打她的,那么你的那位呢,现在就能够做出这么声嘶...

宁城县19326068519: 高分!向您跪下了.C语言程序考试.求高手.急急急★★★★ -
离泡健儿: 给你写前三个吧:1.#include /* 计算个人所得税 */ int main(){ float sr,se,d1,d2,d3,d4,d5,d6,d7,d8,d9; d1=500*0.05; d2=d1+1500*0.1; d3=d2+3000*0.15; d4=d3+15000*0.20; d5=d4+20000*0.25; d6=d5+20000*0.30; d7=d6+20000*0.35; d8=d7+...

宁城县19326068519: 计算机二级C语言是个怎么样的考试………………
离泡健儿: 计算机二级考试,是教育部搞的这么个考试,笔试分公共基础和C语言程序. 公共基础占30分,C语言程序设计70分. 上机有三道题,改错,填空,编程. 过二级不是很难,难的是拿高分.过了C语言二级,给自己加就业的砝码,不错的选择,同时会开发自己的大脑,增强逻辑能力,还为以后学习面向对象的编程打下基础. 加油吧.

宁城县19326068519: C语言基础考试题?高分求解答!!
离泡健儿: 第一题:1 (算数运算符优先级高于逻辑运算符) 此题优先级为 / + == && || 即 a && (b+c) || b == (c/2) 带入数据就是 3 && 9 || 4 == 2 再化简就是 3&&9||0 结果为1 第二题:0,6 数组下标从0开始 第三题:函数 第四题:9 你理解错了 表达式(a,b)...

宁城县19326068519: 问下计算机二级C语言如何考高分? -
离泡健儿: 首先要一台计算机,我们接触的一般都是windows系统,考试的时候也是windows系统.计算机上要安装一个软件,叫visual c++ 6.0,网上搜一下,有绿色版的. 考试你要看书,看什么书要看你要深入到什么程度. 如果是就过了考试的话,那么...

宁城县19326068519: C语言的几道编程题~~跪谢了~~高分 啊! -
离泡健儿: void copyx( char * strDst, const char * strSrc ){ do { if( *strSrc>='a'

宁城县19326068519: C语言简单试题,高分求答案?
离泡健儿: CDDBA,AAC(?结果为3)D 函数,main,main 6 换行符,换行符 非0,0 先判断,再执行;0 0,29 全局变量,局部变量,动态存储变量,静态存储变量 VXXVX,VXXXV,XVVXX hello!++++++++++ 没有输出结果 8,20 b=4,a=2

宁城县19326068519: 高分跪求一C语言程序
离泡健儿:#include <stdio.h> #include <stdlib.h> int itemNumber = 10; void DeleteItem(int arr[10], int n) { int i = 0; for (i = 0; i < 10; i++) { if (arr[i] == n) { if (arr[itemNumber - 1] != n) { arr[i] = arr[itemNumber - 1]; } itemNumber--; } } } void main(void) { int i = 0; int n ...

宁城县19326068519: 高分,求一份 C语言程序 要绝对准确的 因为要考试用的 不能错的
离泡健儿: #include#define YEAR 365 int leap(int year) {int n;n=(year%4==0&&year%4!=0||year%400==0); return(n); } void count(int year, int month) {int i,day,first_day,flag,year1,year2,temp=6;flag=leap(year);year1=year/100; /*相差几百年*/year2=...

宁城县19326068519: 高分跪求 华为 C语言面试题 -
离泡健儿: 华为面试流程、题目及工资水平- - Tag: 华为 华为面试流程一共5轮首先资格考试和面试(相应职位的资深工程师主持);其次应聘职位的部门付经理面试再次应聘职位的部门付经理面试再次人事面试最后是付总级的面试. 常问问题: Q1...

宁城县19326068519: C语言编程题,高分悬赏,求C神!!
离泡健儿:你看看这个怎么样,排序方法是快速排序的最基础的一部分 你可以研究一下快速排序 #include <stdio.h> #include <stdlib.h> int NUM[10][9] = { 6,8,9,1,2,5,4,7,3, 6,8,9,1,2,5,4,7,3, 6,8,9,1,2,5,4,7,3, 6,8,9,1,2,5,4,7,3, 6,8,9,1,2,5,4,7,3, 6,8,9,1,2,5,4,7,3,...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网