嘿嘿 解决了Dev C++ 中文乱码(有效版)

2024-06-04 6608阅读

这是博主第一篇博客!记录一下博主的小小小小解决史!

很早就下载用了Dev c++ ,但现在隔了很长时间没去用过了再次打开发现出现中文乱码的现象!在网站上翻阅了许久!终于解决了问题!困扰了许久!


———————————————————————
嘿嘿 解决了Dev C++ 中文乱码(有效版) 第1张

这个中文乱码看着是真烦得慌!!!

tips:不要急不要急,事情慢慢都能解决掉滴!

还有不要保存在C盘哦!最好都保存在D盘内!本博客示范的未命名1.c 保存于C盘桌面上是为了演示方便!

——————————————————————————— 

图1 这是我们原来出现中文乱码的界面

嘿嘿 解决了Dev C++ 中文乱码(有效版) 第2张

编译的时候会出现这个窗口  

嘿嘿 解决了Dev C++ 中文乱码(有效版) 第3张

图一

嘿嘿 解决了Dev C++ 中文乱码(有效版) 第4张

(再说一遍!这个中文乱码在之前没解决掉问题的时候一看到这个就很烦! )

图二是编译过后(中文乱码版)

嘿嘿 解决了Dev C++ 中文乱码(有效版) 第5张图二 

        —————————————————————————

  • 第一种方法(也是博主强推亲测有效法)

    ·第一步

            请点击左上角左上角

                   选中

    嘿嘿 解决了Dev C++ 中文乱码(有效版) 第6张

    图三   操作第一步    

    ·第二步

             将下方“使用旧版本控制台”勾上 并点击确定

    嘿嘿 解决了Dev C++ 中文乱码(有效版) 第7张

                         图四  控制台点击默认值后的界面

    嘿嘿 解决了Dev C++ 中文乱码(有效版) 第8张

                             图五 勾上下方按钮后 

    嘿嘿 解决了Dev C++ 中文乱码(有效版) 第9张

     图6 点完确定之后再次这个操作出现这样子就代表操作对了!

    ·第三步

            将此.c文件另存为,并选择 ANSI !!!

    嘿嘿 解决了Dev C++ 中文乱码(有效版) 第10张

    嘿嘿 解决了Dev C++ 中文乱码(有效版) 第11张

     图7 选择ANSI!

    ·第四步

    打开记事本 查看右下角是否为ANSI!

    嘿嘿 解决了Dev C++ 中文乱码(有效版) 第12张

    图8 被设置为ANSI的记事本

    嘿嘿 解决了Dev C++ 中文乱码(有效版) 第13张

    图9 未被设置 会出现中文乱码的记事本(看右下角显示得失UTF-8) 

    ·第五步

    点全部重新编译 并运行!就成功啦! 

    嘿嘿 解决了Dev C++ 中文乱码(有效版) 第14张

    图10 太幸福了!看见中文!


    —>不要嫌麻烦!非常有效的一个解决中文乱码的放大 

    ^_^ 提供一个检测是否成功修改好中文乱码的代码

    (出自懒猫老师数据结构课一实验 ,代码不完整但保证正确能顺利跑)

    #include 
    #include
    #include
    #include
    #include
    #define NO_LENGTH  20
    #define NAME_LENGTH 11
    /* 定义学生结构体的数据结构 */
    typedef struct Student{
        char studentNo[NO_LENGTH];
        char studentName[NAME_LENGTH];
    }st;
    /* 定义每条记录或节点的数据结构 */
    typedef struct node
    {
        struct Student data; //数据域
        struct node *next; //指针域
    }Node,*Link;  //Node为node类型的别名,Link为node类型的指针别名
    //定义提示菜单
    void myMenu(){
        printf(" * * * * * * * * * 菜     单 * * * * * * * * * *\n");
        printf("     1 增加学生记录            2 删除学生记录                     \n");
        printf("     3 查找学生记录            4 修改学生记录                     \n");
        printf("     5 统计学生人数            6 显示学生记录                     \n");
        printf("     7 退出系统                                     \n");
        printf(" * * * * * * * * * * * * * * * * * * * * * * * *\n");
    }
    void inputStudent(Link l){
         printf("请输入学生学号:");
         scanf("%s",l->data.studentNo);
         printf("请输入学生的姓名:");
         scanf("%s",l->data.studentName);
         //每个新创建的节点的next域都初始化为NULL
         l->next = NULL;
    }
    void inputStudentNo(char s[],char no[]){
        printf("请输入要%s的学生学号:",s);
        scanf("%s",no);
    }
    void displayNode(Link head){
       // 填写代码,根据传入的链表head头指针,扫描链表显示所有节点的信息
    }
    /* 增加学生记录 */
    bool addNode(Link head){
         Link p,q;   //p,q两个节点一前一后
         Link node;  //node指针指向新创建的节点
         node=(Link)malloc(sizeof(Node));
         inputStudent(node);
         q = head;
         p = head->next;  //q指向head后面的第一个有效节点
         if(head->next==NULL)
             //链表为空时
            head->next = node;
         else {
             //循环访问链表中的所有节点
            while(p != NULL){
                if (node->data.studentNo data.studentNo){
                    //如果node节点的学号比p节点的学号小,则插在p的前面,完成插入后,提前退出子程序
                    q->next = node;
                    node->next = p;
                    return true;
                }
                else{
                    //如果node节点的学号比p节点的学号大,继续向后移动指针(依然保持pq一前一后)
                    q = p;
                    p = p->next;
                }
            }
            //如果没能提前退出循环,则说明之前没有插入,那么当前node节点的学号是最大值,此时插在链表的最后面
            q->next = node;
        }
        return true;
    }
    bool deleteNode(Link head){
        // 按照给定的学号删除学生记录,如果删除成功返回true,如果没找到学号返回false
        
        //输入要处理的学号
            char no[NO_LENGTH];
        inputStudent
    No("查询",no);
        return false;
    }
    bool modifyNode(Link head){
        // 按照给定的学号找到学生记录节点,如果修改成功返回true,如果没找到学号返回false
        
        //输入要处理的学号
        char no[NO_LENGTH];
        inputStudentNo("修改",no);
        return false;
        }
    int countNode(Link head){
        //统计学生人数,扫描链表统计节点个数,返回节点数
        Link p;
        int count = 0;
        p = head->next;
        //填充代码
        return false;
    }
    void clearLink(Link head){
        Link q,p;
            //遍历链表,用free语句删除链表中用malloc建立起的所有的节点
    }
    int main() {
        int select;
            int count;
        Link head;  // 定义链表
        //建立head头结点,在这个程序中head指向头结点,头结点data部分没有内容,其后续节点才有真正的数据
        head = (Link)malloc(sizeof(Node));
        head->next = NULL;
        while(1)
        {
            myMenu();
            printf("\n请输入你的选择(0-7):");  //显示提示信息
            scanf("%d",&select);
            switch(select)
            {
            case 1:
                //增加学生记录
                if(addNode(head))
                    printf("成功插入一个学生记录。\n\n");
                break;
            case 2:
                //删除学生记录
                if(deleteNode(head))
                    printf("成功删除一个学生记录。\n\n");
                else
                    printf("没有找到要删除的学生节点。\n\n");
                break;
            case 3:
                //查询学生记录
                if(queryNode(head))
                    printf("成功找到学生记录。\n\n");
                else
                    printf("没有找到要查询的学生节点。\n\n");
                break;
            case 4:
                //修改学生记录
                if(modifyNode(head))
                    printf("成功修改一个学生记录。\n\n");
                else
                    printf("没有找到要修改的学生节点。\n\n");
                break;
            case 5:
                //统计学生人数
                count = countNode(head);
                printf("学生人数为:%d\n\n",count);
                break;
            case 6:
                //显示学生记录
                displayNode(head);
                break;
            case 7:
                //退出前清除链表中的所有结点
                clearLink(head);
                return 0;
            default:
                printf("输入不正确,应该输入0-7之间的数。\n\n");
                break;
            }
        }
        return 0;
    }


    第二种方法  也是本社区最多人推荐的(但博主没成功哈 !)

    • 第一步

              打开

      嘿嘿 解决了Dev C++ 中文乱码(有效版) 第15张 图一 打开编译选项

      • 嘿嘿 解决了Dev C++ 中文乱码(有效版) 第16张图二 点开后的界面
      • 第二步

                 勾选“编译时加入以下命令 并 输入“-fexec-chart=gbk”后点击确定即可

        • 嘿嘿 解决了Dev C++ 中文乱码(有效版) 第17张

           (此方法不一定适用于所有人 因为我就是那个用这个方法没解决掉的!)



          第三种方法  取自CSDN社区其他博主的博客

          notepad++下载及安装步骤 

          你似乎来到了没有知识存在的荒原 - 知乎嘿嘿 解决了Dev C++ 中文乱码(有效版) 第18张 



          这篇就这样啦!

          如果有其他方法可分享在评论区帮助更多的小白结合问题!

          如 你有更完善的解决方法也可以发在评论区!

           “学习经验值+𝟭”!

          一起加油吧各位 !


    免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

    目录[+]