[문제 설명]

정수형(int)으로 변수를 선언하고, 변수에 정수값을 저장한 후
변수에 저장되어 있는 값을 그대로 출력해보자.

 

[입력]

정수 1개가 입력된다.

[출력]

입력된 정수를 그래도 출력한다.

 

[입력 예시]

15

[출력 예시]

15

 

[코드]

#include<stdio.h>

int main() {
	int a=0;

	scanf("%d", &a);
	printf("%d", a);

	return 0;
}

 

[문제 설명]

이번에는 특수문자를 출력하는 연습을 해보자.

키보드로 입력할 수 없는 다음 모양을 출력해보자.
(** 참고 : 운영체제의 문자 시스템에 따라 아래와 같은 모양이 출력되지 않을 수 있다.)

┌┬┐
├┼┤
└┴┘

참고
다음과 같은 유니코드로 특수문자를 표현한다고 하자.
(운영체제 또는 컴파일러에 따라 사용되는 문자의 코드표가 다르다.)



윈도우에서는 "ㅂ+한자" 키를 누르면 선문자를 입력할 수 있다.
선문자를 이용하면 일반적인 텍스트 모드화면(메모장 등)에서도 표를 그릴 수 있다.

유니코드 특수문자를 출력하는 방법,
...
printf("\u250C\u252C\u2510\n");
...

 

[입력] 

입력 없음

[출력]

┌┬┐
├┼┤
└┴┘
 유니코드를 이용하여 출력한다.

 

[입력 예시]

 

[출력 예시]

┌┬┐

├┼┤

└┴┘

 

[코드]

#include<stdio.h>

int main() {
	printf("\u250c\u252c\u2510\n");
	printf("\u251c\u253c\u2524\n");
	printf("\u2514\u2534\u2518");
	return 0;
}

 

[문제 설명]

윈도우 운영체제의 파일 경로를 출력하는 연습을 해보자.
 
파일 경로에는 특수문자들이 포함된다.

다음 경로를 출력하시오.

"C:\Download\hello.cpp"
(단, 큰따옴표도 함께 출력한다.)

 

[입력]

입력 없음

[출력]

"C:\Download\hello.cpp"
를 출력한다.

[입력 예시]

 

[출력 예시]

"C:\Download\hello.cpp"

 

[코드]

#include<stdio.h>

int main() {
	printf("\"C:\\Download\\hello.cpp\"");
	return 0;
}

 

[문제 설명]

이번에는 특수문자 출력에 도전하자!!

다음 문장을 출력하시오.

"!@#$%^&*()"
(단, 큰따옴표도 함께 출력한다.)

 

[입력]

입력 없음

[출력]

"!@#$%^&*()"
를 출력한다.

 

[입력 예시]

 

[출력 예시]

"!@#$%^&*()"

 

[코드]

#include<stdio.h>

int main() {
	printf("\"!@#$%^&*()\"");
	return 0;
}

 

[문제 설명]

이번에는 큰따옴표(double quotation mark)가 포함된 출력문을 연습해보자.

다음 문장을 출력하시오.

"Hello World"
(단, 큰따옴표도 함께 출력한다.)

 

[입력]

입력 없음

[출력]

"Hello World"
를 출력한다.

 

[입력 예시]

 

[출력 예시]

"Hello World"

 

[코드]

#include<stdio.h>

int main() {
	printf("\"Hello World\"");
	return 0;
}

 

[문제 설명]

이번에는 작은 따옴표(single quotation mark)가 들어있는
특수한 형태의 출력문에 대한 연습을 해보자.

다음 문장을 출력하시오.

'Hello'

※ \' : 작은따옴표 문자 자체 출력

   \" : 큰따옴표 문자 자체 출력

 

[입력]

입력 없음

[출력]

'Hello'
를 출력한다.

[입력 예시]

입력 없음

[출력 예시]

'Hello'

 

[코드]

#include<stdio.h>

int main() {
	printf("\'Hello\'");
	return 0;
}

 

[문제 설명]

이번에는 줄을 바꿔 출력하는 출력문을 연습해보자.
다음과 같이 줄을 바꿔 출력해야 한다.

Hello
World
(두 줄에 걸쳐 줄을 바꿔 출력)

※ '\n' : New Line을 의미. 줄 바꿈

   '\t' : 탭(Tab)

   '\c' : 캐리지리턴(carriage return)을 의미. 그 줄의 맨 앞으로 커서를 보냄

 

[입력]입력 없음[출력]

Hello
World
를 출력한다.

 

[입력 예시]

 

[출력 예시]

Hello

World

 

[코드]

#include<stdio.h>

int main() {
	printf("Hello\nWorld");
	return 0;
}

 

[문제 설명]

이번에는 공백()을 포함한 문장을 출력한다.
다음 문장을 출력해보자.

Hello World
(대소문자에 주의한다.)

 

[입력]

입력 없음]

[출력]

Hello World

를 출력한다.

 

[입력 예시]

 

[출력 예시]

Hello World

 

[코드]

#include<stdio.h>

int main(){
    printf("Hello World");
    return 0;
}

 

[문제 설명]

다음과 같은 n*m 배열 구조를 출력해보자.

입력이 3 4인 경우 다음과 같이 출력한다.
12 7 6 1
11 8 5 2
10 9 4 3

입력이 4 5인 경우는 다음과 같이 출력한다.
17 16 9 8 1
18 15 10 7 2
19 14 11 6 3
20 13 12 5 4

입력이 n m인 경우의 2차원 배열을 출력해보자.

 

[입력]

첫 번째 줄에 배열의 크기 n m이 입력된다.
[입력값의 정의역]
1<=  n,m <= 100

[출력]

n*m 크기의 배열을 설명과 같이 채워 출력한다.

 

[입력 예시]

2 3

[출력 예시]

5 4 1

6 3 2

 

[코드]

#include<stdio.h>

int main() {
	int a[100][100];
	int n, m, i, j, cnt;

	scanf("%d %d", &n, &m);

	for (j = 0; j < m; j++) {
		if(m % 2 == 1)
			if (j % 2 == 0)
				cnt = (m - j) * n-(n-1);
			else
				cnt = (m - j) * n;
		else
			if (j % 2 == 1)
				cnt = (m - j) * n - (n - 1);
			else
				cnt = (m - j) * n;
		for (i = 0; i < n; i++) {
			a[i][j] = cnt;
			if(m % 2 == 0)
				if (j % 2 == 1)
					cnt++;
				else
					cnt--;
			else
				if (j % 2 == 1)
					cnt--;
				else
					cnt++;
		}
	}

	for (i = 0; i < n; i++) {
		for (j = 0; j < m; j++)
			printf("%d ", a[i][j]);
		printf("\n");
	}

	return 0;
}

 

 

[문제 설명]

다음과 같은 n*m 배열 구조를 출력해보자.

입력이 3 4인 경우 다음과 같이 출력한다.
10 9 4 3
11 8 5 2
12 7 6 1

입력이 4 5인 경우는 다음과 같이 출력한다.
20 13 12 5 4
19 14 11 6 3
18 15 10 7 2
17 16 9 8 1

입력이 n m인 경우의 2차원 배열을 출력해보자.

 

[입력]

첫 번째 줄에 배열의 크기 n m이 입력된다.
[입력값의 정의역]
1<=  n,m <= 100

[출력]

n*m 크기의 배열을 설명과 같이 채워 출력한다.

 

[입력 예시]

2 3

[출력 예시]

6 3 2

5 4 1

 

[코드]

#include<stdio.h>

int main() {
	int a[100][100];
	int n, m, i, j, cnt;

	scanf("%d %d", &n, &m);

	for (j = 0; j < m; j++) {
		if(m % 2 == 0)
			if (j % 2 == 0)
				cnt = (m - j) * n-(n-1);
			else
				cnt = (m - j) * n;
		else
			if (j % 2 == 1)
				cnt = (m - j) * n - (n - 1);
			else
				cnt = (m - j) * n;
		for (i = 0; i < n; i++) {
			a[i][j] = cnt;
			if(m % 2 == 0)
				if (j % 2 == 0)
					cnt++;
				else
					cnt--;
			else
				if (j % 2 == 0)
					cnt--;
				else
					cnt++;
		}
	}

	for (i = 0; i < n; i++) {
		for (j = 0; j < m; j++)
			printf("%d ", a[i][j]);
		printf("\n");
	}

	return 0;
}

 

+ Recent posts