题目链接:https://vjudge.net/problem/UVA-227#author=0

题解:这个题不难但需要注意很多点

1.需要输入空格,而cin不读取空格,所以需要getchar,而getchar与NULL联系时,优先级过低,需要加()。

2.每次都需要换行,换行需要getchar()

3.我一开始就报错Runtime error,原因是,最后就算到0到6,越界,也进行运算,那么行数就会变为-1,就越界了,解决办法时加个if

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
char qi[7][7];
int main()
{
    int cou=0;
    memset(qi,0,sizeof(qi));
    while((qi[1][1]=getchar())!=NULL)//cin自动忽略空格,而getchar优先级比较低,需要加()
    {
        cou++;
        int flag=1;
        if(qi[1][1]=='Z') break;
        for(int i=2;i<=5;i++)
            qi[1][i]=getchar();
        getchar();
        for(int j=2;j<=5;j++)
        {
           for(int i=1;i<=5;i++)
                qi[j][i]=getchar();
            getchar();
        }
        int bx,by;
        for(int i=1;i<=5;i++)
            for(int j=1;j<=5;j++)
            if(qi[i][j]==' ')
        {
            bx=i;
            by=j;
        }
        char ch,t;
        for(;;)
        {
            ch=getchar();
            if(ch=='0') break;

if(flag==1)
            {
               if(ch=='A')
           {
                qi[bx][by]=qi[bx-1][by];
                qi[bx-1][by]=' ';
                bx--;
                if(bx==0) flag=0;
            }
            else if(ch=='B')
            {
                qi[bx][by]=qi[bx+1][by];
                qi[bx+1][by]=' ';
                bx++;
                if(bx==6) flag=0;
            }
            else if(ch=='L')
            {
                qi[bx][by]=qi[bx][by-1];
                qi[bx][by-1]=' ';
                by--;
                if(by==0) flag=0;
            }
            else if(ch=='R')
            {
                qi[bx][by]=qi[bx][by+1];
                qi[bx][by+1]=' ';
                by++;
                if(by==6) flag=0;
            }
            }
        }
        getchar();
        if(cou>1) cout<<endl;
        cout<<"Puzzle #"<<cou<<":"<<endl;
        if(flag==0) cout<<"This puzzle has no final configuration."<<endl;
        else
        {
            for(int i=1;i<=5;i++)
            {
                for(int j=1;j<=5;j++)
                {
                    if(j!=1) cout<<' ';
                    cout<<qi[i][j];
                }
                cout<<endl;
            }
        }
        memset(qi,0,sizeof(qi));
    }
    return 0;
}

处理字符getchar()-------Puzzle的更多相关文章

  1. 关于getchar()的知识

    char* s1 = "123",字符串"123"这段内存是只读的,就是说其内容不能改变///char *s 这个是指申请一个地址空间 记录一个地址 #incl ...

  2. getchar getche getch的区别

    getchar 由宏实现:#define getchar() getc(stdin). getchar有一个int型的返回值.当程序调用getchar时.程序就等着用户按键.用户输入的字符被存放在键盘 ...

  3. C++/VC中ANSI与UNICODE中字符定义和函数对照表

    这样查起来方便多了 ANSI UNICODE 通用 说明 数据类型 (char.h) (wchar.h) (tchar.h)   char wchar_t TCHAR   char * wchar_t ...

  4. 关于getchar的一些思考

    这个问题是有一段代码引起的: 代码1: #include<iostream> using namespace std; int main() { char t; t=getchar(); ...

  5. getchar() getch() getche() gets() puts() scanf()的用法及区别

    getchar() putchar(ch) scanf()   头文件stdio.h getch() getche()   头文件conio.h gets() puts()    头文件stdio.h ...

  6. getchar,scanf以及缓冲区

    getchar()是stdio.h中的库函数,它的作用是从stdin流中读入一个字符,也就是说,如果stdin有数据的话不用输入它就可以直接读取了.getch()和getche()是conio.h中的 ...

  7. c/c++学习系列之putchar、getchar、puts、gets的运用

    如果您只想取得使用者输入的字元,則可以使用getchar(),它直接取得使用者輸入的字元并传回,如果只想要输出一個字元,則也可以直接使用putchar(),以下是个简单的例子: #include &l ...

  8. scanf函数与getchar函数

    #define _CRT_SECURE_NO_WARNINGS#include<stdio.h>#include<string.h>#include<stdlib.h&g ...

  9. 《UNIX环境高级编程》笔记——2.标准和实现

    随着UNIX各种衍生版本不断发展壮大,标准化工作就十分必要.其实干啥事都是这样,玩的人多了,必须进行标准化. 一.UNIX标准 1.1 ISO C(ANSI C) ANSI:Amerocan Nato ...

随机推荐

  1. 彻底搞懂Redis主从复制原理及实战

    欢迎关注公众号:「码农富哥」,致力于分享后端技术 (高并发架构,分布式集群系统,消息队列中间件,网络,微服务,Linux, TCP/IP, HTTP, MySQL, Redis), Python 等 ...

  2. bugku 一个神奇的登录框

    一个登录界面,填个admin,123试试,提示try again 抓包看看. 在admin后加个’提示try again 看来是被过滤了,试试” 报错了,加上# 报错没有了,说明存在注入点. 先来判断 ...

  3. Python实用笔记 (17)模块

    一个abc.py的文件就是一个名字叫abc的模块,一个xyz.py的文件就是一个名字叫xyz的模块. 现在,假设我们的abc和xyz这两个模块名字与其他模块冲突了,于是我们可以通过包来组织模块,避免冲 ...

  4. JavaScript基础有关构造函数、new关键字和this关键字(009)

    1. 总是记得用new关键字来执行构造函数.前面提到,可以用构造函数创建JavaScript的对象,这个构造函数在使用的时候需要使用new关键字,但如果忘记写入new关键字,会怎么样?事实上这个函数还 ...

  5. scheduler的调度规则

    对爬虫的请求进行调度管理 允许接收requests并且会调度一个request去下载,且具有去重机制 优先级和队列不会被调度器执行(调度器不管优先级的问题),用户使用字段给每个Request对象,可以 ...

  6. Appium移动端自动化测试--搭建模拟器和真机测试环境

    详细介绍安装Android Studio及Android SDK.安装Appium Server. 文章目录如下 目录 文章目录如下 模拟器--安装Android Studio及Android SDK ...

  7. css3动画的性能优化_针对移动端卡顿问题

    这篇文章主要讲的是怎样制作流畅动画,特别是针对移动端.在这里我首先介绍制作动画的几种方法的优缺点:接着会着重介绍用css3制作动画的注意事项. 资源网站大全 https://55wd.com 设计导航 ...

  8. 三色二叉树——树形dp

    三色二叉树 题目描述 一棵二叉树可以按照如下规则表示成一个由 \(0.1.2\) 组成的字符序列,我们称之为"二叉树序列 \(S\) ": \(0\) 该树没有子节点. \(1S_ ...

  9. Linux终端音乐播放器cmus攻略: 操作歌单

    目录 1. 安装 2. 操作说明 2.1. *PlayList歌单 2.2. 其他 3. 视图切换 4. 使响应Media/play按键 4.1. 编译安装 cmus是一款开源的终端音乐播放器.它小巧 ...

  10. 工作那么久,才知道的 SOLID 设计原则

    认识 SOLID 原则 无论是软件系统设计,还是代码实现,遵循有效和明确的设计原则,都利于系统软件灵活可靠,安全快速的落地,更重要的是能灵活地应对需求,简化系统扩展和维护,避免无效的加班.本文主要讨论 ...