IO第一天

1.请用fscanf和fprintf实现文件拷贝。 (fputc和fgetc)

2.实现登录功能。自定义一个usr.txt,手动输入账户密码,格式如下:账户 密码

例如: zhangsan 12345

lisi abcde

wangwu abc123

需求如下:

从终端获取账户密码,与文件中的账户密码比较

若终端输入的账户不存在,则输出账户不存在

若终端输入的账户存在,但是密码不正确,则输出密码错误

若账户密码均正确,则输出登录成功

复制代码
#include <stdio.h>
int main(int argc, const char *argv[])
{
//判断命令行是否传参	
	if(argc<2)
	{
		printf("命令行未传参,请输入文件名");
		return -1;
	}
	//以读的形式打开文件
	FILE* MAX = fopen(argv[1],"r");
	//判断MAX是否为空
	if(NULL == MAX)
	{
		perror("floen");
		return -1;
	}
	//int sizf存储文件的大小
	int sizf = 0;
	char c;
	//循环读取文件中的单个字符并判断文件是否读取完毕
	//scanf中的%s,%d,%f不会获取换行,空格,制表符
	//      %c可以获取换行,空格,制表符
	FILE* ppt = fopen("./mont.txt","w");
	while(fscanf(MAX,"%c",&c)!=EOF)
	{
		fprintf(ppt,"%c",c);
		sizf++;
	}
	printf("拷贝成功\n");
	//打印文件大小
	printf("sizf=%d\n",sizf);

	fclose(ppt);

	fclose(MAX);

return 0;
}
复制代码
#include <stdio.h>                                 
#include <string.h>
int main(int argc, const char *argv[])
{
	FILE*max = fopen("./pasword.txt","w");
	if(NULL == max)
	{
		perror("fopen");
		return -1;
	}
	printf("请输入账号和密码\n");
	char num[20] = "";
	char main[20] = "";
	scanf("%s %s",num,main);
	getchar();
	fprintf(max,"%s %s",num,main);
	fclose(max);

    FILE*pb=fopen("./pasword.txt","r");
    if(pb==NULL)
    {
        printf("创建失败\n");
        perror("fopen");
        return -1;
    }
    char arr[20],str[20];
    fscanf(pb,"%s %s",arr,str);
    fflush(pb);
 
    printf("请输入账号和密码\n");
    char arr1[20],brr[20];
    scanf("%s %s",arr1,brr);
    int a,b;
    a=strcmp(arr,arr1);
    b=strcmp(str,brr);
    if(a!=0)
    {
        printf("账号错误\n");
        return -1;
    }
    else if(a==0)
    {
        printf("账号正确\n");
    }
    if(b!=0)
    {
        printf("密码错误\n");
        return -1;
    }
    else if(b==0)
    {
        printf("密码正确\n");
    }
    printf("登录成功\n");
    fclose(pb);
}
相关推荐
_清歌4 小时前
DSpark 深度解读:DeepSeek-V4 如何用「半自回归」把推理速度提升 85%
算法
统计实现局4 小时前
SVD 的三步走:双对角化、Givens 收敛、排序
算法
躬行见万象4 小时前
《VLA 系列》UniLab 强化训练 | G1 机器人 |复现
算法
统计实现局4 小时前
对称不定分解(Bunch-Kaufman):为什么 Cholesky 不够用
算法
统计实现局4 小时前
dqrsl 拆解:拿着 QR 结果能算出哪 5 种东西
算法
统计实现局4 小时前
为什么 Cholesky 求逆比 Gauss-Jordan 快一倍——行列式溢出防护详
算法
To_OC16 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
金銀銅鐵19 小时前
[Python] 扩展欧几里得算法
python·数学·算法
To_OC21 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode