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);
}
相关推荐
2301_7890156222 分钟前
DS进阶:AVL树
开发语言·数据结构·c++·算法
zyq99101_14 小时前
优化二分查找:前缀和降复杂度
数据结构·python·蓝桥杯
qyzm4 小时前
天梯赛练习(3月13日)
开发语言·数据结构·python·算法·贪心算法
逆境不可逃4 小时前
LeetCode 热题 100 之 64. 最小路径和 5. 最长回文子串 1143. 最长公共子序列 72. 编辑距离
算法·leetcode·动态规划
CoderCodingNo4 小时前
【GESP】C++五级练习题 luogu-P1182 数列分段 Section II
开发语言·c++·算法
放下华子我只抽RuiKe54 小时前
机器学习全景指南-直觉篇——基于距离的 K-近邻 (KNN) 算法
人工智能·gpt·算法·机器学习·语言模型·chatgpt·ai编程
kisshuan123964 小时前
[特殊字符]【深度学习】DA3METRIC-LARGE单目深度估计算法详解
人工智能·深度学习·算法
sali-tec5 小时前
C# 基于OpenCv的视觉工作流-章33-Blod分析
图像处理·人工智能·opencv·算法·计算机视觉
Eward-an5 小时前
LeetCode 239. 滑动窗口最大值(详细技术解析)
python·算法·leetcode
一叶落4386 小时前
LeetCode 50. Pow(x, n)(快速幂详解 | C语言实现)
c语言·算法·leetcode