题目链接: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. Jmeter系列(34)- 详解 Counter 计数器

    如果你想从头学习Jmeter,可以看看这个系列的文章哦 https://www.cnblogs.com/poloyy/category/1746599.html 简单介绍 计数器的作用:循环递增生成数 ...

  2. PHP输入流

    PHP输入流php://input,对于这个的官方解释是: php://input可以读取没有处理过的POST数据.相较于$HTTP_RAW_POST_DATA而言,它给内存带来的压力较小,并且不需要 ...

  3. 错误C2280 Union:尝试引用已删除的函数

    在编写Union共用体类型的时候,写了如下代码,在第5行出现错误: #include <iostream> #include <string> using namespace ...

  4. 【未完待续】MVC 之HTML辅助方法

    顾名思义,HTML辅助方法(HTML Helper)就是用来辅助产生HTML之用, 在开发View的时候一定会面对许多HTML标签,处理这些HTML的工作非常繁琐,为了降低View的复杂度,可以使用H ...

  5. Spring Aware介绍

    读完这篇文章你将会收获到 Aware 的使用和介绍 BeanFactoryAware 的触发时机 ApplicationContextAware 的触发时机以及它通过扩展 BeanPostProces ...

  6. Codeforces 1215D Ticket Game 题解

    Codeforces 1215D Ticket Game 原题 题目 Monocarp and Bicarp live in Berland, where every bus ticket consi ...

  7. Mysql如何取当日的数据

    下面的sql语句可以取出当日的数据 SELECT * FROM table WHERE 时间字段 BETWEEN DATE_FORMAT(NOW(),'%Y-%m-%d 00:00:00') AND ...

  8. sql语句-CASE WHEN用法详解

    当我们需要从数据源上 直接判断数据显示代表的含义的时候 ,就可以在SQL语句中使用 Case When这个函数了. Case具有两种格式.简单Case函数和Case搜索函数. 第一种 格式 : 简单C ...

  9. [JAVA]字符串常量池String pool

    字符串常量池(String Pool)保存着所有字符串字面量(literal strings),这些字面量在编译时期就确定.不仅如此,还可以使用 String 的 intern() 方法在运行过程中将 ...

  10. Window - 安装 ant

    官方下载地址 https://ant.apache.org/bindownload.cgi 旧版下载地址 https://archive.apache.org/dist/ant/binaries/ 挑 ...