Ⅰ c语言程序设计,通讯录管理系统
/*【用C语言编写具有数据插入、修改、删除、显示和查询功能的电话薄管理程序】
1、数据包括:人名、工作单位、电话号码和E-mail地址。
2、可对记录中的姓名和电话号码进行修改。
3、可增加或删除记录。
4、可显示所有保存的记录。
5、可按人名或电话号码进行查询。
另:采用结构体数组和文件系统实现。结构体包括人名、工作单位、电话号码和E-mail
绝对原创,2010年7月12日晚刚写完测试通过的,纯C语言! */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define szSTR 64
#define fileDB "c:\\contact.txt"
struct CONTACT {
char name[szSTR];/*姓名*/
char unit[szSTR];/*工作单位*/
char tele[szSTR];/*电话*/
char mail[szSTR];/*mail*/
};
typedef struct CONTACT CON;
#define BNAME 1
#define BUNIT 2
#define BTELE 4
#define BMAIL 8
#define BFULL 0xFF
int OPER[5] = {BFULL, BNAME, BUNIT, BTELE, BMAIL};
void input(CON * s, int mask)
{
if(mask & BNAME) { printf("请输入学生姓名:"); scanf("%s", s->name); }
if(mask & BUNIT) { printf("请输入工作单位:"); scanf("%s", s->unit); }
if(mask & BTELE) { printf("请输入联系电话:"); scanf("%s", s->tele); }
if(mask & BMAIL) { printf("请输入电子邮件:"); scanf("%s", s->mail); }
}/*end input*/
void show (int id, CON * s)
{
if(!s) return ;
if(id)
printf("%d\t%s\t%s\t%s\t%s\n",
id, s->name , s->unit , s->tele , s->mail );
else
printf("【姓名】%s【工作单位】%s【电话】%s【电邮】%s\n",
s->name , s->unit , s->tele , s->mail );
/*end if*/
}/*end show*/
void regist(void)
{
CON s; FILE * f = 0;
input(&s, BFULL);
f = fopen(fileDB, "ab");
fwrite(&s,sizeof(s),1,f);
fclose(f);
printf("资料已保存!\n");
}/*end regist*/
int browse(char * key, fpos_t * p, CON * s)
{
FILE * f =0; int i = 0, r = 0; CON t;
char * a = 0, * b = 0; fpos_t q;
if(!s) return 0;
f = fopen(fileDB, "rb");
if(!f) {
printf("数据库暂无记录\n");
return 0;
}/*end if*/
printf("编号\t姓名\t单位\t电话\t电邮\n");
printf("------------------------------------------------\n");
while(!feof(f)) {
fgetpos(f, &q);
r = fread(&t, sizeof(t), 1, f);
if(r<1)break;
if(t.name[0]==0) continue;
if(key) {
a = strstr(t.name , key);
b = strstr(t.tele , key);
if(a == 0 && b == 0) continue;
}/*end if*/
if(p) *p = q;
if(s) memcpy(s, &t, sizeof(t));
i++;
show(i, &t);
}/*end while*/
fclose(f);
printf("------------------------------------------------\n");
return i;
}/*end browse*/
fpos_t query(CON * s)
{
char key[szSTR]=""; fpos_t p = 0; int r = 0;
printf("请输入姓名或者电话号码:");
scanf("%s", key);
r = browse(key, &p, s);
return r?p:-1;
}/*end query*/
void clear(void)
{
FILE * f = 0; CON s;
fpos_t p = query(&s);
if(p<0) return;
f = fopen(fileDB, "rb+");
fsetpos(f, &p);
memset(&s, 0, sizeof(s));
fwrite(&s, sizeof(s),1, f);
fclose(f);
printf("记录已删除!\n");
}/*end clear*/
void modify(void)
{
FILE * f = 0; CON s; int cmd = 0;
fpos_t p = query(&s);
if(p<0) return;
f = fopen(fileDB, "rb+");
fsetpos(f, &p);
for(;;) {
show(0, &s);
printf("请选择:1-姓名;2-工作单位;3-电话;4-电邮;5-保存并退出;6-放弃修改并退出\n");
scanf("%d", &cmd);
switch(cmd) {
case 1:
case 2:
case 3:
case 4:
input(&s, OPER[cmd]);
break;
case 5:
fsetpos(f, &p);
fwrite(&s, sizeof(s), 1, f);
case 6:
fclose(f);
return;
default:
printf("错误的操作,请重新输入。\n");
}/*end case*/
}/*mext*/
}/*end clear*/
int main(void)
{
int cmd = 0; CON s;
for(;;) {
printf("欢迎使用通信簿!请选择:1-添加;2-查询;3-删除;4-修改;5-全部输出;0-退出\n");
scanf("%d", &cmd);
switch(cmd) {
case 0: return 0;
case 1: regist(); break;
case 2: query(&s); break;
case 3: clear(); break;
case 4: modify(); break;
case 5: browse(0, 0, &s); break;
}//end case
}
return 0;
}
Ⅱ c语言编写一个程序计算长途电话费。电话费根据以下费率计算:
自己先试着写,有问题了在慢慢解决!!!不要一味地等别人写好了,当个“拿来党”
Ⅲ C语言话费计算程序
#include<stdio.h>
#defineSHZF0.20//SHZF为市话标准资费
//以下函数将通话时长折算成分钟
intminu(inthour,intminute,intsecond)
{
minute=minute+hour>0?minute*60:0;//小时折算成分钟
minute=minute+second>0?1:0;//不足1分钟按折算成1分钟
returnminute;//返回通话时间(单位:分钟)
}
voidmain()
{
doublemoney=0;//总话费
inttotal_minute=0;//总通话时长(分钟)
inthour,minute,second;//通话时长的小时数、分钟数、秒数
printf(" 请输入第1次通话时长:");
scanf("%d:%d:%d:",&hour,&minute,&second);//输入时间
total_minute+=minute+minu(hour,minute,second);//调用函数求通话时间(分)
printf(" 请输入第2次通话时长:");
scanf("%d:%d:%d:",&hour,&minute,&second);
total_minute+=minute+minu(hour,minute,second);
printf(" 请输入第3次通话时长:");
scanf("%d:%d:%d:",&hour,&minute,&second);
total_minute+=minute+minu(hour,minute,second);
money=total_minute*SHZF;//计算话费
printf("今天话费是:%f ",money);
}
Ⅳ c语言编程(关于电话费的问题)
走过一秒也算0.15吗?如果是何不统一换算成秒数来算,,对60取模,不为零则多加一个月的。。
Ⅳ C语言,编写一个简单的通讯录管理系统
实现一个通讯录管理系统;
通讯录管理系统可以用来存储1000个人的信息,每个人的信息包括:
姓名、性别、年龄、电话、住址
**提供方法:
1. 添加联系人信息
2. 删除指定联系人信息
3. 查找指定联系人信息
4. 修改指定联系人信息
5. 显示所有联系人信息
6. 清空所有联系人
7. 以名字排序所有联系人**
1、linkman.h(头文件)
3、程序运行结果部分示范:
Ⅵ c语言编写一个程序计算长途电话费。电话费根据以下费率计算: 1)周一到周五,上午八点到下午六点之间
#include <stdio.h>
int main()
{
char str[2];
int b,c,d,flag=0;
double e=0;
scanf("%s %d %d %d",&str,&b,&c,&d);
if((str[0]=='m' ||str[0]=='M') &&(str[1]=='O' ||str[1]=='o'))
flag=1;
if((str[0]=='t' ||str[0]=='T') &&(str[1]=='u' ||str[1]=='U'))
flag=1;
if((str[0]=='w' ||str[0]=='W') &&(str[1]=='e' ||str[1]=='E'))
flag=1;
if((str[0]=='T' ||str[0]=='t') &&(str[1]=='H' ||str[1]=='h'))
flag=1;
if((str[0]=='f' ||str[0]=='F') &&(str[1]=='r' ||str[1]=='R'))
flag=1;
if((str[0]=='S' ||str[0]=='s') &&(str[1]=='A' ||str[1]=='a'))
flag=2;
if((str[0]=='s' ||str[0]=='S') &&(str[1]=='u' ||str[1]=='U'))
flag=2;
while(str!="\0")
{
if(flag==2)
e=d*0.15;
if(flag==1 && (60*b+c>=0 && 60*b+c<=480 && 60*b+c+d<=480 ))
e=d*0.25;
if(flag==1 && (60*b+c>=1080 && 60*b+c<=1440 && 60*b+c+d<=1440 ))
e=d*0.25;
if(flag==1 && (60*b+c>480 && 60*b+c<1080 && 60*b+c+d<1080 ))
e=d*0.4;
if(flag==1 && (60*b+c>=0 && 60*b+c<=480 && 60*b+c+d>=480 && 60*b+c+d<=1080 ))
e=(480-(60*b+c))*0.25+(d-(480-(60*b+c)))*0.4;
if(flag==1 && (60*b+c>=0 && 60*b+c<=480 && 60*b+c+d>=1080 && 60*b+c+d<=1440 ))
e=(480-(60*b+c))*0.25+(1080-480)*0.4+(d-(480-(60*b+c))-(1080-480))*0.25;
if(flag==1 && (60*b+c>480 && 60*b+c<1080 && 60*b+c+d>=1080 && 60*b+c+d<=1440 ))
e=(1080-(60*b+c))*0.4+(d-(1080-(60*b+c)))*0.25;
printf("%lf\n",e);
scanf("%s %d %d %d",&str,&b,&c,&d);
}
return 0;
}
Ⅶ C语言,编写一个简单的通讯录管理系统
实现一个通讯录管理系统;
通讯录管理系统可以用来存储1000个人的信息,每个人的信息包括:
姓名、性别、年龄、电话、住址
**提供方法:
1. 添加联系人信息
2. 删除指定联系人信息
3. 查找指定联系人信息
4. 修改指定联系人信息
5. 显示所有联系人信息
6. 清空所有联系人
7. 以名字排序所有联系人**
1、linkman.h(头文件)
3、程序运行结果部分示范:
Ⅷ C语言题目 计算电话费
这个问题使用简单的判断if语句就可以完成了。
#include<stdio.h>
int main()
{ int a,b,c,n,y;
scanf("%d",&n);
while(n--)
{ scanf("%d%d",&a,&b);
c=a+b;
if(c<=300)y=3*a+6*b;
else if(c<=500)y=0.9*3*a+6*b;
else if(c<=1000)y=0.75*3*a+0.9*6*b;
else y=0.5*3*a+0.75*6*b;
printf("%d\n",y);
}
return 0;
}
Ⅸ c语言编程题 设计一个机房收费管理系统,实现对学生上机收费的管理。 功能描述如下: (1)输入功能
你好!这是一个机房收费管理系统截图,基本可以满足你的要求
Ⅹ c语言 电话簿管理系统
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include <iostream>
//主函数
int main()
{
LinkQueue Q;
initAddressBook(Q);
int flag=0;
while(flag!=8)
{
printf("※※※※※主※※※※※菜※※※※※单※※※※※\n");
printf("※1、增加联系人 2、删除联系人 ※\n");
printf("※3、修改联系人 4、清空通讯录 ※\n");
printf("※5、查找联系人 6、按组显示 ※\n");
printf("※7、显示全部联系人 8、退出 ※\n");
printf("※※※※※※※※※※※※※※※※※※※※※※※\n");
printf("请输入编号(1-8):\n");
scanf("%d",&flag);
if(flag<1||flag>8)
{
printf("输入错误请重新输入!\n");
continue;
}
else
{
switch(flag){
case 1:
if(enAddressBook(Q))
printf("增加联系人成功!\n");
else
printf("增加联系人失败!\n");
break;
case 2:
if(delPerson(Q))
printf("删除联系人成功!\n");
else
printf("联系人删除失败!\n");
break;
case 3:
if(update(Q))
printf("修改联系人成功!\n");
else
printf("修改联系人失败!\n");
break;
case 4:
if(clearAddressBook(Q))
printf("通讯录已清空!\n");
else
printf("通讯录清空失败!\n");
break;
case 5:
findByName(Q);
break;
case 6:
findByGroup(Q);
break;
case 7:
disAll(Q);
break;
case 8:
system("cls");
break;
}
}
}
printf("※※※※※感谢您使用本系统!※※※※※※\n");
return 0;
}
//初始化通讯录
void initAddressBook(LinkQueue &Q)
{
Q.front=Q.rear=(QNode *)malloc(sizeof(QNode));
if(!Q.front)
exit(1);
else
Q.front->next=NULL;
}
//清空通讯录
bool clearAddressBook(LinkQueue &Q)
{
system("cls");
while(addressBookLength(Q)!=0)
{
QNode *p;
p=Q.front->next;
Q.front->next=p->next;
if(p==Q.rear)
Q.rear=Q.front;
free(p);
}
return true;
}
//通讯录当前人数
int addressBookLength(LinkQueue &Q)
{
int i=0;
QNode *p;
p=Q.front;
if(Q.front==Q.rear)
i=0;
else
{
while(p!=Q.rear)
{
p=p->next;
i++;
}
}
return i;
}
//删除联系人
bool delPerson(LinkQueue &Q)
{
char _name[20];
system("cls");
printf("请输入要删除的联系人的姓名:\n");
scanf("%s",_name);
QNode *p,*q;
if(Q.front==Q.rear)
{
printf("通讯录为空!\n");
return false;
}
else
{
p=Q.front;
q=Q.front->next;
while(q!=Q.rear){
if(strcmp(q->name,_name)==0)
{
p->next=q->next;
free(q);//删除节点
return true;
}
else
{
p=p->next;
q=q->next;
}
}
if((strcmp(q->name,_name)==0))
{
free(q);
Q.front=Q.rear;
return true;
}
else
{
printf("无此联系人!\n");
return false;
}
}
}
//查找联系人
bool findByName(LinkQueue &Q)
{
system("cls");
if(Q.front==Q.rear)
{
printf("手机中无联系人!\n");
return false;
}
else
{
char _name[20];
printf("请输入要查询的联系人姓名:\n");
scanf("%s",_name);
QNode *p;
p=Q.front->next;
while(p->next!=NULL)
{
if(strcmp(p->name,_name)==0)
{
printf("姓名:%s 号码:%s 分组:%s\n",p->name,p->tel,p->group);
return true;
}
p=p->next;
}
if(strcmp(p->name,_name)==0){
printf("姓名:%s 号码:%s 分组:%s\n",p->name,p->tel,p->group);
return true;
}
else
{
printf("查无此人!\n");
return false;
}
}
}
//按组显示联系人
bool findByGroup(LinkQueue &Q)
{
system("cls");
if(Q.front==Q.rear)
{
printf("手机中无联系人!\n");
return false;
}
else
{
char _group[20];
printf("请输入要查询的分组:\n");
scanf("%s",_group);
QNode *p;
p=Q.front->next;
while(p->next!=NULL)
{
if(strcmp(p->group,_group)==0)
{
printf("姓名:%s 号码:%s \n",p->name,p->tel);
}
p=p->next;
}
if(strcmp(p->group,_group)==0){
printf("姓名:%s 号码:%s \n",p->name,p->tel);
return true;
}
else
{
printf("无此分组!\n");
return false;
}
}
}
//增加联系人
bool enAddressBook(LinkQueue &Q)
{
system("cls");
QNode *p;
p=(QNode *)malloc(sizeof(QNode));
if(!p)
return false;
else
{
printf("请输入联系人姓名:\n");
scanf("%s",p->name);
printf("请输入联系人号码:\n");
scanf("%s",&p->tel);
printf("请输入联系人分组:\n");
scanf("%s",p->group);
if(Q.front->next==NULL)
{
Q.front->next=p;
Q.rear=p;
Q.rear->next=NULL;
}
else
{
p->next=NULL;
Q.rear->next=p;
Q.rear=p;
}
return true;
}
}
//修改联系人
bool update(LinkQueue &Q)
{
system("cls");
if(Q.front==Q.rear)
{
printf("手机中无联系人!\n");
return false;
}
else
{
char _name[20];
printf("请输入要修改的联系人姓名:\n");
scanf("%s",_name);
QNode *p;
p=Q.front->next;
while(p->next!=NULL)
{
if(strcmp(p->name,_name)==0)
{
printf("请输入新联系人姓名:\n");
scanf("%s",p->name);
printf("请输入新联系人号码:\n");
scanf("%s",&p->tel);
printf("请输入新联系人分组:\n");
scanf("%s",p->group);
return true;
}
p=p->next;
}
if(strcmp(p->name,_name)==0){
printf("请输入新联系人姓名:\n");
scanf("%s",p->name);
printf("请输入新联系人号码:\n");
scanf("%s",&p->tel);
printf("请输入新联系人分组:\n");
scanf("%s",p->group);
return true;
}
else
{
printf("查无此人!\n");
return false;
}
}
}
//显示所有联系人
void disAll(LinkQueue &Q)
{
system("cls");
int i=0;
QNode *p;
p=Q.front->next;
if(Q.front==Q.rear)
printf("无联系人!\n");
else
{
printf(" 姓名 号码 分组\n");
while(p!=NULL){
printf("%15s %15s %15s\n",p->name,p->tel,p->group);
p=p->next;
}
}
}