标准IO作业

1、完成标准io的单字符、字符串、格式化、模块化实现两个文件的拷贝;

#include<myhead.h>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include<errno.h>
#include<time.h>

int main(int argc, const char *argv[])
{
FILE *fp =fopen(argv[1],"r");
if(fp==NULL)
{
perror("-1");
}
FILE *op=fopen(argv[2],"w"   );
if(op==NULL)
{
perror("-1");
}
char buf =0;
int count;
while(1)
{
buf=fgetc(fp);
if(buf==EOF)
{
break ;

}
fputc(buf,op);


}
fclose(fp);

fclose(op);
}
#include<myhead.h>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include<errno.h>
#include<time.h>

int main(int argc, const char *argv[])
{
FILE *fp =fopen(argv[1],"r");
if(fp==NULL)
{
perror("-1");
}
FILE *op=fopen(argv[2],"w"   );
if(op==NULL)
{
perror("-1");
}
char buf[100] =" ";

while(1)
{
char*s=fgets(buf,sizeof(buf),fp);

fputs(buf,op);
if(s==NULL)
{

break;
}




}







fclose(fp);

fclose(op);
}
#include<myhead.h>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include<errno.h>
#include<time.h>

int main(int argc, const char *argv[])
{
FILE *fp =fopen(argv[1],"r");
if(fp==NULL)
{
perror("-1");
}
FILE *op=fopen(argv[2],"w"   );
if(op==NULL)
{
perror("-1");
}
float  num;
int y,m,r,h,min,s;
while(fscanf(fp,"%f %d-%d-%d %d:%d:%d", &num,&y,&m,&r,&h,&min,&s )==7)
{
fprintf(op,"%.2f,%04d-%02d-%02d %02d:%02d:%02d\n", num,y,m,r,h,min,s );

}







fclose(fp);

fclose(op);
}

#include<myhead.h>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include<errno.h>
#include<time.h>

int main(int argc, const char *argv[])
{
FILE *fp =fopen(argv[1],"r");
if(fp==NULL)
{
perror("-1");
}
FILE *op=fopen(argv[2],"w"   );
if(op==NULL)
{
perror("-1");
}

char arr[256]="0";
fread(arr,sizeof(arr),1,fp);
fwrite(arr,1,strlen(arr),op);





fclose(fp);

fclose(op);
}

#include<myhead.h>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include<errno.h>
#include<time.h>


int main(int argc, const char *argv[]) {
    FILE *fp = fopen(argv[1], "a+"); // 以追加和读写模式打开文件
    if (fp == NULL) {
        perror("-1");
        return 1; // 退出程序
    }

    while (1) {
        printf("1. 登录\n");
        printf("2. 注册\n");
        int a = 0;
        scanf("%d", &a);
        getchar(); // 清除换行符

        switch (a) {
            case 1: {
                char arr[9] = "";
                char brr[20] = "";

                printf("请输入账号:\n");
                fgets(arr, sizeof(arr), stdin);
                printf("请输入密码:\n");
                fgets(brr, sizeof(brr), stdin);

                arr[strcspn(arr, "\n")] = '\0'; // 去掉换行符
                brr[strcspn(brr, "\n")] = '\0'; // 去掉换行符

                // 重新设置文件指针到开头
                fseek(fp, 0, SEEK_SET);

                char bcc[9];  // 从文件中读取的账号
                char baa[21]; // 从文件中读取的密码
                int found = 0; // 用于标记是否找到匹配的账号和密码

                while (fgets(bcc, sizeof(bcc), fp) != NULL) {
                    // 读取账号
                    bcc[strcspn(bcc, "\n")] = '\0'; // 去掉换行符
                    printf("读取的账号: %s\n", bcc); // 调试输出

                    if (fgets(baa, sizeof(baa), fp) == NULL) {
                        break; // 如果没有密码了,退出循环
                    }
                    baa[strcspn(baa, "\n")] = '\0'; // 去掉换行符
                    printf("读取的密码: %s\n", baa); // 调试输出

                    // 检查账号和密码是否匹配
                    if (strcmp(bcc, arr) == 0 && strcmp(baa, brr) == 0) {
                        printf("登录成功\n");
                        found = 1; // 设置为找到
                        break; // 找到匹配后退出循环
                    }
                }

                // 如果没有找到匹配的账号和密码
                if (!found) {
                    printf("账号或密码错误,请重新输入或注册\n");
                }
                break;
            }
            case 2: {
                printf("请输入账号:");
                char crr[9] = "";
                fgets(crr, sizeof(crr), stdin);
                crr[strcspn(crr, "\n")] = '\0'; // 去掉换行符
                fputs(crr, fp);
                fputs("\n", fp);
                printf("请输入密码:");
                char drr[20] = "";
                fgets(drr, sizeof(drr), stdin);
                drr[strcspn(drr, "\n")] = '\0'; // 去掉换行符
                fputs(drr, fp);
                fputs("\n", fp);
                printf("添加成功\n");

                // 读取并输出文件内容以确认写入
                printf("当前文件内容:\n");
                fseek(fp, 0, SEEK_SET);
                char line[50]; // 存储一行的缓冲区
                while (fgets(line, sizeof(line), fp) != NULL) {
                    printf("%s", line);
                }
                break;
            }
            default:
                printf("无效的选择,请重新输入\n");
                break;
        }
    }

    fclose(fp);
    return 0;
}
相关推荐
福大大架构师每日一题8 分钟前
文心一言 VS 讯飞星火 VS chatgpt (396)-- 算法导论25.2 1题
算法·文心一言
EterNity_TiMe_23 分钟前
【论文复现】(CLIP)文本也能和图像配对
python·学习·算法·性能优化·数据分析·clip
机器学习之心33 分钟前
一区北方苍鹰算法优化+创新改进Transformer!NGO-Transformer-LSTM多变量回归预测
算法·lstm·transformer·北方苍鹰算法优化·多变量回归预测·ngo-transformer
yyt_cdeyyds44 分钟前
FIFO和LRU算法实现操作系统中主存管理
算法
alphaTao1 小时前
LeetCode 每日一题 2024/11/18-2024/11/24
算法·leetcode
kitesxian1 小时前
Leetcode448. 找到所有数组中消失的数字(HOT100)+Leetcode139. 单词拆分(HOT100)
数据结构·算法·leetcode
VertexGeek2 小时前
Rust学习(八):异常处理和宏编程:
学习·算法·rust
石小石Orz2 小时前
Three.js + AI:AI 算法生成 3D 萤火虫飞舞效果~
javascript·人工智能·算法
jiao_mrswang3 小时前
leetcode-18-四数之和
算法·leetcode·职场和发展
qystca3 小时前
洛谷 B3637 最长上升子序列 C语言 记忆化搜索->‘正序‘dp
c语言·开发语言·算法