2014/6/19

对输入输出流的深入理解,以及文件处理。
//1.cpp
#include
#include
using namespace std;
typedef struct BOOK{ char book_id[5]; char book_name[11]; char author[7]; double price; }book;
int main()
{
book bk[10];
ofstream out("ST1.DAT");//文件输入流。输入数据到文本中 
int N;
cout << "请输入书本数:" << endl;
cin >> N;
cout << "请按序严格输入书号(6个字符) 书名(12个) 作者(8个) 单价(2位小数)" << endl;
for (int i = 0; i < N; i++)
{
cin >> bk[i].book_id >> bk[i].book_name >> bk[i].author >> bk[i].price;
}
for (int i = 0; i < N; i++)
{
//out << "书号   " << "书名   " << "作者" << "单价   " << endl;
out << bk[i].book_id << " " << bk[i].book_name << " " << bk[i].author << " " << bk[i].price;
}
out.close();
return 0;
}//输入完毕后 对书本数的多少是不知道的,只知道里面有哪些变量。
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
//2.cpp
#include
#include //字符串处理 头文件
#include //文件处理  头文件
using namespace std;
typedef struct BOOK
{
char book_id[5]; char book_name[11]; char author[7]; double price;
};
int search(BOOK bk[], int n, char s[]);//设置搜索函数
int main()
{
int s = 1;
BOOK bk[10];
ifstream in("ST1.DAT");
while (!in.eof())//读取文件数据 当最后一个字符为0时结束读取
{
in >> bk[s].book_id >> bk[s].book_name >> bk[s].author >> bk[s].price;//打开文件输入到结构体中
s++;//计算有多少本书
}
in.close();//文件关闭
//for (int s = 0; s < i;s++)
// cout << bk[s].book_id << " " << bk[s].book_name << " " <<bk[s].author << " " << bk[s].price << endl;
cout << "价钱大于三十圆的书:" << endl;
for (int i = 0; i
{
if (bk[i].price>30)//价钱大于30元的判断
{
cout << bk[i].book_id << " " << bk[i].book_name << " " << bk[i].author << " " << bk[i].price << endl;
}
}
cout << "查找一本书:";
char book_find[5];
cin >> book_find;
int d;
d = search(bk, s, book_find);
if (d)
{
cout << bk[d].book_id << " " << bk[d].book_name << " " << bk[d].author << " " << bk[d].price << endl;
}
else
cout << "没有这本书!" << endl;
return 0;
}
int search(BOOK bk[], int n, char s[])
{
int i;
for (i = 0; i < n; i++)
{
if (strcmp(bk[i].book_id, s) == 0)//strcmp 两串相等,返回0 
return i;
}
return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值