#UVa:11956-Brainfuck

灆洢 2015-03-15 01:20:14

照著題目要求的去改陣列的值即可,它的陣列指標位置操作是循環的,意思就是說若指標在0的地方,做減一應該會到陣列最尾巴,反之亦然。

C++(0.498)

/*******************************************************/
/* UVa 11956 Brainfuck                                 */
/* Author: Maplewing [at] knightzone.studio            */
/* Version: 2015/03/15                                 */
/*******************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int main(){
  int testcase;

  while( scanf("%d", &testcase) != EOF ){
    getchar(); /* for '\n' */
    int caseCount;
    for( caseCount = 1 ; caseCount <= testcase ; ++caseCount ){
      unsigned char array[105] = {0};
      int index = 0;

      char input[100005];
      gets(input);

      int inputLength = strlen(input);
      int i;
      for( i = 0 ; i < inputLength ; ++i ){
        switch(input[i]){
          case '>':
            ++index;
            break;
          case '<':
            --index;
            break;
          case '+':
            ++array[index];
            break;
          case '-':
            --array[index];
            break;
        }

        index = (index + 100) % 100;
      }

      printf("Case %d:", testcase);
      for( i = 0 ; i < 100 ; ++i ){
        printf(" %02X", array[i] );
      }
      printf("\n");
    }
  }
  return 0;
}

在〈“#UVa:11956-Brainfuck”〉中有 2 則留言

  1. lee mean04表示:

    this is wrong

發表迴響

這個網站採用 Akismet 服務減少垃圾留言。進一步瞭解 Akismet 如何處理網站訪客的留言資料