반응형

변수

변수는 값을 담는 상자이다.

 

A라는 상자가 존재 할 때 내가 원하는 형태의 값을 담을 수 있다

 

A = 5 

 

5라는 값을 A의 상자의 공간에 넣어준다고 해석할 수 있다. 

 

수학의 개념 A = 5

'A는 5다' 라는 개념과 다른 개념이다. 

 

숫자형

정수형 - 0, 1, 2, -3

a = -3	 #a에 -3을 넣는다
print(a) #값 출력
print(type(a)) #a의 자료형 타입 int(integer) 정수형을 의미

실수형 - 0.123, -4.567, 3.9e10

(컴퓨터 지수 표현 방식 e,E 어느 것을 사용해도 무방 e10 = 10^10 -e10 = 10^-10)

f = 0.123	   
print(f)	   
print(type(f)) #float => 실수자료형

 

8진수 - 0o123

 

16진수 - 0x6F

 

사칙연산

x = 3
y = 4
print(x+y)  #더하기
print(x-y)  #빼기
print(x*y)  #곱하기
print(x**y) #제곱
print(x/y)  #나누기
print(x//y) #나누기 : 몫
print(x%y)  #나머지

 

문자열

문자열은 따옴표를 이용해 표현할 수 있으며 그 방법은 4가지 이다.

'파이썬의 세계에 오신걸 환영합니다.'
"파이썬의 세계에 오신걸 환영합니다."
'''파이썬의 세계에 오신걸 환영합니다.'''
"""파이썬의 세계에 오신걸 환영합니다."""
a = "Hello Python" #문자열도 마찬가지로 변수에 담을 수 있다.
print(type(a))     #str 문자열의 자료형을 뜻하는 string의 약자 str을 쓴다.

여러개의 따옴표를 쓰는 이유는 문자열 안에 ' 과 "을 표현하기 위해서이다.

x = 'I say "I love python.".'    #따옴표 안에 따옴표
y = "I say \" I love python.\"." #백슬래시 \ 이용

이스케이프 코드

파이썬은 한줄씩 처리하기 때문에 줄 바꿈이나 탭 등 여러가지 형식으로 만들어주거나 기능이나 문자를 넣을 수 있는 코드이다.

#\n	줄을 바꿀 때 사용
#\t	간격을 줄 때 사용
#\\	문자 \를 표현할 때 사용
#\'	작은따옴표(')를 표현할 때 사용
#\"	큰따옴표(")를 표현할 때 사용
#\r	캐리지 리턴(줄 바꿈 문자, 현재 커서를 가장 앞으로 이동)
#\f	폼 피드(줄 바꿈 문자, 현재 커서를 다음 줄로 이동)
#\a	벨 소리(PC 스피커에서 '삑' 소리가 난다)
#\b	백 스페이스
#\000 널 문자

 

문자열 연산

#문자열 연결
a = "Hello"
b = " Python"
a+b #Hello Python

#문자열 곱셈
a = "Python"
a * 3 #문자열 a인 Python을 3번 반복하여 출력한다.

#문자열 길이
a = "Hello Python"
len(a) #12

 

문자열 인덱싱과 슬라이싱

인덱싱 - 하나의 값을 가리킨다

슬라이싱 - 여러개의 값을 잘라낸다.

#인덱싱
a = "Hello Python"
a[0]
# H
a[3]
#l
#문자열의 시작번호는 0번째부터 시작이다.
a[-1]
#n #거꾸로 간다

#슬라이싱
b = a[0]+a[6]
#HP
a[0:4] # => a[:4] 
#Hello
#값을 넣지않으면 끝부분까지라고 생각하면된다. a[4:] => 4번째부터 끝까지

a[0:5:2] #세번째 자리는 간격만큼 건너 출력한다.
#Hlo

 

문자열 포매팅

a = "I want %d oranges." %5 
#여러가지 자료형의 삽입이 가능하다 ex)%d - 5 => %s - five
#변수에 초기화 후 변수 삽입도 가능하다
number = 5
a = "I want %d oranges." % number
a
#I want 5 oranges

#문자열 포맷 코드
#%s	문자열
#%c	문자 1개
#%d	정수
#%f	부동소수
#%o	8진수
#%x	16진수
#%%	Literal % (문자 % 자체)

 

문자열 관련 함수

 

문자열 세기(count)

a = "Hello Python"
a.count('2')
#2 l의 개수

 

문자 위치 탐색1(find)

a = "Hello Python"
a.find('o')
#4 숫자를 0부터 세고 가장 먼저 나온 위치를 반환하기 때문에 Hello의 4번째의 o를 반환한다.
a.find('f')
#-1 존재하지 않으면 -1을 반환한다.

 

문자 위치 탐색2(index)

a = "Hello Python"
a.index('o')
#4 find와 동일하다 하지만 존재하지 않는다면 오류가 발생한다.

 

문자열 삽입(join)

",".join("Hello")
#문자열 Hello 가각 사이에 ','를 삽입한다.

 

소문자->대문자(upper)

a = "Hello Python"
a.upper()
#"hello python"

 

대문자->소문자(lower)

a = "Hello Python"
a.lower()
#"HELLO PYTHON"

 

공백 지우기(strip, rstrip, lstrip)

a = '  hello  '
a.rstrip() #오른쪽 공백 지우기 '  hello'
a.lstrip() #왼쪽 공백 지우기   'hello'
a = '  hello  '
a.strip()  #공백 지우기 'hello'

 

문자열 바꾸기(replace)

a = "Hello Python"
a.replace("Python","C++")
#"Hello C++"

 

문자열 나누기(split)

a = "Hello Python"
a.split() #()공간에 아무것도 쓰지 않으면 공백기준
#['Hello','Python']

#그 외에 기준을 두고 싶으면 '?' ?에 다른 값을 넣어주면 된다
a = "H:i" 
a.split(':')
#['H','i']

 

반응형
반응형

코인을 하던 저는

20살에 접어들면서 운전을 할 수 있게 되고 

차에 대해 관심을 가지게 되었는데요.

 

그 중 자동차와 관련된 코인 중 하나인 아모(AMO) 코인에 대해 알아볼려고 합니다.

 

아모(AMO) 코인이란?

영어로 자동차를 뜻하는 Automobile 에서 따왔으며, 모든 드라이빙 데이터를 공유하는 블록체인 네트워크입니다.

즉,

자동차 데이터 시장에서 자동차의 주행, 주차, 충전, 결제, 통신 등

운전자의 모든 데이터를 공유 및 거래에서 사용되는 가상화폐입니다.

 

그럼 이 데이터를 어디에 쓰느냐?

현 시대에 가장 가치있는 것은 '정보' 이라고 생각합니다.

뭐든지 '얼마나 '정보'를 가지고 또는 알고 있는가?' 에 따라 달라진다고 할 수 있죠.

이 때 우리의 주행데이터를 기반으로 자동차관련 서비스들을 제공할 수 있습니다.

자동차의 내부 데이터(주행 관련), 자동차의 외부 데이터(운전자의 운행 중 사용하는 데이터)

이 두가지를 통해 운전자의 운전과 소비의 습관이나 취향 등을 알 수 있고

이를 통해 자동차회사나 관련 서비스 회사에서 사용자에 맞춘 상품들을 기획하거나

많은 사용자의 운전을 통해 자율주행으로도 이어질 수 있습니다. 

 

아모코인은 아모 마켓에 자신의 자동차 데이터를 업로드 하면, 데이터 소유자의 허가가 있을 시에만

데이터가 거래되며, 거래될 때마다 아모코인으로 보상 받을 수 있습니다.

 

향후 자동차 관련 서비스에 사용 될 수 있겟죠.

 

그럼 이 코인을 만든 회사 아모 랩스(AMO Laps)는 무슨회사냐?

한국의 정보보안 전문업체인 펜타시큐리티시스템의 자회사로서

2007년부터 커넥티드 카, 자율주행차 그리고 전기차를 위한 보안 솔루션을 개발해 왔습니다.

2015년에는 자동차에서 인프라까지 아우르는 자동차 보안 토탈 솔루션 AutoCrypt®를 출시했습니다.

AutoCrypt®(아우토크립트)

협력형 교통지능체계 C-ITS 사업, 자율협력주행 기술개발 사업, 자율주행차 실험도시 조성 사업 등에 참여하며 자돛아 보안 사업의 핵심 역할을 맡고 있습니다.

AMO의 핵심 기술로서 안전한 자동차 환경을 위한 기술을 제공합니다.

 

C-ITS란 무엇이냐

간단히 차량이 주행 중 운전자에게 주변 교통상황과 급정거,

낙하물 등의 사고 위험 정보를 실시간으로 제공하는 시스템 입니다.

운전하시다 보면 현재 교통상황을 검토해서

경로를 재탐색하는 시스템이 바로 이 시스템을 이용한 것입니다.

 

지금까지 아모랩스는

2007

차량과 차량 진단 장치 간 데이터 보안

2011

차량과 모바일 단말기 간 데이터 보안

2012

경찰 순찰차 출동 관리 시스템 보안

2013

WAVE 통신 환경의 V2X 보안

2014

모바일 텔레매틱스 보안

VDMS(차량 데이터 모니터링 시스템)보안

2016

대전광역시-세종시 C-ITS사업 보안인증시스템 구축

2017

전기차 충전 시스템 보안

대전광역시-세종시 보안인증시스템 개선 사업

여주 고속도로 C-ARS 사업 보안인증시스템 구축

화성시 K-City 보안인증시스템 구축

2018

C-ITS 고속도로 보안 솔류션 기획

2019

제주도 C-ITS 프로젝트 참여

서울시 C-ITS 프로젝트 참여

C-ITS 고속도로 보안 솔루션 구축

2021년 계획

 2021년 드디어 데이터를 수집하네요

이 밖에도 중국과 일본에 사업을 추진하고 있습니다.

 

앞서 말했듯이 사실상 데이터들은 자율주행에 필요한 것들입니다.

그럼 자율주행에 상용화됨에 따라 데이터의 가치가 더욱 더 높아질 것입니다.

그리고 그 데이터를 얼마나 잘 지키는가?

바로 보안이 가장 중요합니다.

 

그에 대해 설명을 잘 해주신 영상이 있어 남겨봅니다.

https://www.youtube.com/watch?v=nFCJK40YLoE&t=348s

 

아모코인 차트

총 발행량 196억입니다.

테슬라에서 비트코인을 사용하겠다고 선언한 뒤

폭등으로 18원 까지 올랐으나

이후 계속된 하락장과 악재 

테슬라 비트코인 사용중단으로 인해 

폭락 중입니다.

허나 장기적으로 본다면 나쁘지 않을 것 같습니다.

모두 성투하시길 바랍니다.

 

https://www.amo.foundation/

 

아모랩스 (AMO Labs) 홈페이지 | Discover value in your driving

AMO는 주행 정보와 차량 정보 등 다양한 드라이빙 데이터를 수집하고 활용함으로써 더 나은 차량 환경을 만드는 데이터 플랫폼입니다. AMO Coin은 여러분의 데이터에 가치를 더합니다. 지금 바로, A

www.amo.foundation

 

아모코인 상장거래소

https://www.bithumb.com/trade/order/AMO_KRW

 

No.1 가상자산 플랫폼, 빗썸, 아모코인 거래소

아모코인(AMO)거래소, 아모코인(AMO)가격、아모코인(AMO)시세 정보 제공, 아모코인(AMO) 매매, 아모코인(AMO) 매수, 아모코인(AMO) 매도, 아모코인(AMO) 거래

www.bithumb.com

https://coinone.co.kr/exchange/trade/amo/krw

 

아모코인(AMO) - 코인원(Coinone) 시세 확인 및 거래하기

아모코인(AMO) 거래소, 아모코인(AMO) 시세 정보 제공, 아모코인(AMO) 매매, 아모코인(AMO) 매수, 아모코인(AMO) 매도, 아모코인(AMO) 거래

coinone.co.kr

아모코인 공식 채팅방입니다.

https://open.kakao.com/o/gVFIQnab 비밀번호 : 109629

 

AMO Labs - Official 2.0

#blockchain #amo #pentasecurity #자동차

open.kakao.com

 

반응형
반응형

오늘은 클레이튼 코인에 대해 알아볼려고 합니다.

대부분 사람들은 클레이튼코인은 카카오에 관련되어 있어서

관심을 가지고 투자를 합니다.

하지만 그정도로만 다들 알고 있고, 자세히는 모르시는 분들이 많아서 알아보았습니다.

 

클레이튼이란?

카카오의 블록체인 기술 관련 자회사 그라운드X가 개발한 코인입니다.

클레이튼은 비트코인처럼 하나의 코인이 아닌 이더리움이나 이오스 같이 분산 어플리케이션 디앱을 만들기 위한 중앙 플랫폼입니다.

 

여기서!

분산어플리케이션이란?

'특정 관리자가 없는 어플리케이션으로

여러 마이너들이 어플리케이션의 네트워크를 유지해준다.'

라는 의미입니다. 

하지만 네트워크를 유지하는 역할만 있을뿐 고치거나 관리하지는 못합니다.

 

제일 궁금해 하실 것들

클레이튼의 발행량은 100억개를 시작으로 매년 2.91%씩 증가한답니다.

현 시세는 2021-05-23 23:57 기준 1380원이네요..

(처음 봤을 때 2400원에 봤는데...)

최근들어 악재와 조정이 심각하네요.

거의 2018년 리플의 형태를 보는 것 같네요...

그러나 많은 사람들이 그렇듯이 '카카오'라는 이름 하나 만으로 

장기로 투자 할 가치는 있다고 봅니다.

 

컨소시엄 노드

그라운드X와 함께 클레이튼 플랫폼을 운영 및 활용하는 파트너들입니다.

플랫폼 거버넌스를 달성하고자 하는 공통의 목표를 공유하는 기여자 그룹과  함께 클레이튼을 운영하고 있습니다.

따라서 합의가 필요한 중요 작업은 컨소시엄 노드에서 처리합니다. 

그라운드X는 이 모임을 클레이튼 거버넌스 카운슬이라고 명명했습니다.

 

그냥 쉽게 말해서 클레이튼과 함께 운영하고 이 클레이튼을 활용하는 기업들이라고 생각하시면 됩니다.

 

카카오를 기준으로 많은 회사들이 협력하고 있습니다. 

그 중에는 우리가 잘 알고있는 대기업들도 보입니다.

 

이 밖에도 더 많은 활용처, 개발팀 등 수많은 기업들과 협력하고 있습니다.

단지 카카오뿐만이 아니란거 

 

작년 그라운드 X CEO 한재선님과의 인터뷰자료입니다.

https://www.youtube.com/watch?v=KT-NhmOxqwo

클레이튼은 현재도 여러 사업을 추진하고 있어서 앞으로도 크게 성장할 것으로 봅니다.

하지만 현재는 중국의 암호화폐 강력 규제로 인해 많은 코인들이 피해를 보고 있습니다.

사실상 많은 코인들, 암호화폐라는 이름으로 만들어진 이상

실사용되는 곳이 있어야 가격이 올라갈 것으로 생각됩니다.

즉,

모든 코인은 미래적 가치를 보고 투자하는 것이니 신중히 투자하시길 바랍니다.

 

아래는 그라운드X 홈페이지입니다.

https://www.groundx.xyz/

 

Ground X

The Future Designed by Ground X

www.groundx.xyz

아래는 클레이튼 거래소 입니다.

https://www.bithumb.com/trade/order/KLAY_KRW 빗썸

 

No.1 가상자산 플랫폼, 빗썸, 클레이튼 거래소

클레이튼(KLAY)거래소, 클레이튼(KLAY)가격、클레이튼(KLAY)시세 정보 제공, 클레이튼(KLAY) 매매, 클레이튼(KLAY) 매수, 클레이튼(KLAY) 매도, 클레이튼(KLAY) 거래

www.bithumb.com

https://coinone.co.kr/exchange/trade/klay/krw 코인원

 

클레이튼(KLAY) - 코인원(Coinone) 시세 확인 및 거래하기

클레이튼(KLAY) 거래소, 클레이튼(KLAY) 시세 정보 제공, 클레이튼(KLAY) 매매, 클레이튼(KLAY) 매수, 클레이튼(KLAY) 매도, 클레이튼(KLAY) 거래

coinone.co.kr

 

반응형
반응형

문제 5, 6번에 적용되는 BaseArray 클래스는 다음과 같다.

class BaseArray {
private:
	int capacity; // 배열의 크기
	int* mem; // 정수 배열을 만들기 위한 메모리의 포인터
protected:
	BaseArray(int capacity = 100)
	{
		this->capacity = capacity; mem = new int[capacity];
	}
	~BaseArray() { delete[]mem; }
	void put(int index, int val) { mem[index] = val; }
	int get(int index) { return mem[index]; }
	int getCapacity() { return capacity; }
};

 

문제

BaseArray를 상속받아 큐처럼 작동하는 MyQueue클래스를 작성하라. MyQueue를 활용하는 사례는 다음과 같다.

int main()
{
	MyQueue mQ(100);
	int n;
	cout << "큐에 삽입할 5개의 정수를 입력하라>> ";
	for (int i = 0; i < 5; i++)
	{
		cin >> n;
		mQ.enqueue(n); //큐에 삽입
	}
	cout << "큐의 용량 : " << mQ.capacity() << ", 큐의 크기 : " << mQ.length() << endl;
	cout << "큐의 원소를 순서대로 제거하여 출력한다>> ";
	while (mQ.length() != 0) {
		cout << mQ.dequeue() << ' '; //큐에서 제거하여 출력
	}
	cout << endl << "큐의 현재 크기 : " << mQ.length() << endl;
}

 

결과

큐에 삽입할 5개의 정수를 입력하라>> 1 3 5 7 9

큐의 용량:100, 큐의 크기:5

큐의 원소를 순서대로 제거하여 출력한다>> 1 3 5 7 9

큐의 현재 크기 : 0

 

소스코드

#include<iostream>
using namespace std;
class BaseArray {
private:
	int capacity; // 배열의 크기
	int* mem; // 정수 배열을 만들기 위한 메모리의 포인터
protected:
	BaseArray(int capacity = 100)
	{
		this->capacity = capacity; mem = new int[capacity];
	}
	~BaseArray() { delete[]mem; }
	void put(int index, int val) { mem[index] = val; }
	int get(int index) { return mem[index]; }
	int getCapacity() { return capacity; }
};
class MyQueue : public BaseArray {
	int front, rear;
public:
	MyQueue(int capacity) : BaseArray(capacity) { front = 0; rear = 0; }
	void enqueue(int data);
	int dequeue();
	int capacity();
	int length();
};
void MyQueue::enqueue(int data)
{
	if (rear >= getCapacity()) {
		cout << "큐가 가득찼습니다." << endl;
		exit(1);
	}
	put(++rear, data);
}
int MyQueue::dequeue()
{
	if (front == rear) {
		cout << "꺼낼 데이터가 없습니다." << endl;
		exit(1);
	}
	--rear;
	return get(++front);
}
int MyQueue::capacity()
{
	return getCapacity();
}
int MyQueue::length()
{
	return rear;
}
int main()
{
	MyQueue mQ(100);
	int n;
	cout << "큐에 삽입할 5개의 정수를 입력하라>> ";
	for (int i = 0; i < 5; i++)
	{
		cin >> n;
		mQ.enqueue(n); //큐에 삽입
	}
	cout << "큐의 용량 : " << mQ.capacity() << ", 큐의 크기 : " << mQ.length() << endl;
	cout << "큐의 원소를 순서대로 제거하여 출력한다>> ";
	while (mQ.length() != 0) {
		cout << mQ.dequeue() << ' '; //큐에서 제거하여 출력
	}
	cout << endl << "큐의 현재 크기 : " << mQ.length() << endl;
}
반응형
반응형

문제 3, 4번에 적용되는 2차원 상의 한 점을 표현하는 Point 클래스가 있다.

class Point {
	int x, y;
public:
	Point(int x, int y) { this->x = x; this->y = y; }
	int getX() { return x; }
	int getY() { return y; }
protected:
	void move(int x, int y) {
		this->x = x; this->y = y;
	}
};

 

문제

다음 main() 함수가 실행되도록 Point 클래스를 상속받는 ColorPoint 클래스를 작성하고, 전체 프로그램을 완성하라.

int main() {
	ColorPoint zeroPoint;
	zeroPoint.show();

	ColorPoint cp(5, 5);
	cp.setPoint(10, 20);
	cp.setColor("BLUE");
	cp.show();
}

 

결과

BLACK색으로 ( 0, 0 )에 위치한 점입니다.

BLUE색으로 ( 10, 20 )에 위치한 점입니다.

 

소스코드

#include<iostream>
#include<string>
using namespace std;
class Point {
	int x, y;
public:
	Point(int x, int y) { this->x = x; this->y = y; }
	int getX() { return x; }
	int getY() { return y; }
protected:
	void move(int x, int y) { this->x = x; this->y = y; }
};
class ColorPoint : public Point {
	string color;
public:
	ColorPoint(int x = 0, int y = 0, string color = "BLACK") : Point(x, y) {
		this->color = color;
	}
	void show();
	void setPoint(int x, int y);
	void setColor(string color);
};
void ColorPoint::show()
{
	cout << color << "색으로 ( " << getX() << ", " << getY() << " )에 위치한 점입니다." << endl;
}
void ColorPoint::setPoint(int x, int y)
{
	move(x, y);
}
void ColorPoint::setColor(string color)
{
	this->color = color;
}
int main() {
	ColorPoint zeroPoint;
	zeroPoint.show();

	ColorPoint cp(5, 5);
	cp.setPoint(10, 20);
	cp.setColor("BLUE");
	cp.show();
}

 

반응형
반응형

문제 3, 4번에 적용되는 2차원 상의 한 점을 표현하는 Point 클래스가 있다.

class Point {
	int x, y;
public:
	Point(int x, int y) { this->x = x; this->y = y; }
	int getX() { return x; }
	int getY() { return y; }
protected:
	void move(int x, int y) {
		this->x = x; this->y = y;
	}
};

 

문제

다음 main() 함수가 실행되도록 Point 클래스를 상속받은 ColorPoint 클래스를 작성하고, 전체 프로그램을 완성하라.

int main() {
	ColorPoint cp(5, 5, "RED");
	cp.setPoint(10, 20);
	cp.setColor("BLUE");
	cp.show();
}

 

결과

BLUE색으로 ( 10, 20 )에 위치한 점입니다.

 

소스코드

#include<iostream>
#include<string>
using namespace std;
class Point {
	int x, y;
public:
	Point(int x, int y) { this->x = x; this->y = y; }
	int getX() { return x; }
	int getY() { return y; }
protected:
	void move(int x, int y) {
		this->x = x; this->y = y;
	}
};
class ColorPoint : public Point {
	string color;
public:
	ColorPoint(int x, int y, string color);
	void setPoint(int x, int y);
	void setColor(string color);
	void show();
};
ColorPoint::ColorPoint(int x, int y, string color) : Point(x, y) {
	this->color = color;
}
void ColorPoint::setPoint(int x, int y)
{
	move(x, y);
}
void ColorPoint::setColor(string color)
{
	this->color = color;
}
void ColorPoint::show() {
	cout << color << "색으로 ( " << getX() << ", " << getY() << " )에 위치한 점입니다." << endl;
}
int main() {
	ColorPoint cp(5, 5, "RED");
	cp.setPoint(10, 20);
	cp.setColor("BLUE");
	cp.show();
}

설명

원칙적으로 파생 클래스의 생성자를 작성할 떄, 기본 클래스의 생성자 중 하나를 선택해야 한다. 하지만 선택하지 않을 경우 컴파일러가 암묵적으로 기본 클래스의 기본 생성자를 호출하도록 컴파일한다. 그러므로 ColorPoint의 생성자를 선언 할 때 : Point(x, y) 을 선언해 주지 않으면 기본 생성자를 호출하려고 하며, Point의 기본생성자가 존재하지 않으므로 컴파일 오류가 난다. 

반응형
반응형

문제 1, 2번에 적용도는 원을 추상화한 Circle 클래스가 있다.

class Circle {
	int radius;
public:
	Circle(int radius = 0) { this->radius = radius; }
	int getRadius() { return radius;}
	void setRadius(int radius) { this->radius = radius; }
	double getArea() { return 3.14 * radius * radius; }
};

 

문제

다음과 같이 배열을 선언하여 다음 실행 결과가 나오도록 Circle을 상속받은 NamedCircle 클래스와 main() 함수 등 필요한 함수를 작성하라.

NamedCircle pizza[5];

 

결과

5 개의 정수 반지름과 원의 이름을 입력하세요

1>> 5 크림피자

2>> 8 치즈피자

3>> 25 대왕피자

4>> 30 블랙홀피자

5>> 15 마늘피자

 

소스코드

#include<iostream>
#include<string>
using namespace std;
class Circle {
	int radius;
public:
	Circle(int radius = 0) { this->radius = radius; }
	int getRadius() { return radius; }
	void setRadius(int radius) { this->radius = radius; }
	double getArea() { return 3.14 * radius * radius; }
};
class NamedCircle : public Circle {
	string name;
public:
	NamedCircle() {};
	string getName() { return name; }
	void setName(string name) { this->name = name; }
};
int main()
{
	NamedCircle pizza[5];
	int r;
	string name;
	int count = 0;
	cout << "5 개의 정수 반지름과 원의 이름을 입력하세요" << endl;
	for (int i = 0; i < 5; i++)
	{
		cout << i + 1 << ">>";
		cin >> r >> name;
		pizza[i].setRadius(r);
		pizza[i].setName(name);
	}
	for (int i = 0; i < 4; i++)
	{
		if (pizza[i].getRadius() < pizza[i + 1].getRadius())
			count = i + 1;
	}
	cout << "가장 면적이 큰 피자는 " << pizza[count].getName() << "입니다." << endl;
}

설명

Circle과 같은 원리인 함수 NamedCircle클래스에 선언해 준 후 Circle의 멤버 함수와 NamedCircle의 멤버 함수를 이용하여 값들을 저장하고 반지름의 크기만 비교하여 가장 큰 곳의 인덱스를 기억하여 출력한다.

반응형
반응형

문제 1, 2번에 적용도는 원을 추상화한 Circle 클래스가 있다.

class Circle {
	int radius;
public:
	Circle(int radius = 0) { this->radius = radius; }
	int getRadius() { return radius;}
	void setRadius(int radius) { this->radius = radius; }
	double getArea() { return 3.14 * radius * radius; }
};

 

문제

다음 코드가 실행되도록 Circle을 상속받는 NamedCircle 클래스를 작성하고 전체 프로그램을 완성하라.

int main()
{
	NamedCircle waffle(3, "waffle"); //반지름이 3이고 이름이 waffle인 원
	waffle.show();
}

 

결과

반지름이 3인 waffle

 

소스코드

#include<iostream>
#include<string>
using namespace std;
class Circle {
	int radius;
public:
	Circle(int radius = 0) { this->radius = radius; }
	int getRadius() { return radius;}
	void setRadius(int radius) { this->radius = radius; }
	double getArea() { return 3.14 * radius * radius; }
};
class NamedCircle : public Circle {
	string name;
public:
	NamedCircle(int r, string name);
	void show();
};
NamedCircle::NamedCircle(int r, string name)
{
	setRadius(r);
	this->name = name;
}
void NamedCircle::show()
{
	cout << "반지름이 " << getRadius() << "인 " << name << endl;
}
int main()
{
	NamedCircle waffle(3, "waffle"); //반지름이 3이고 이름이 waffle인 원
	waffle.show();
}

설명

Circle을 상속받으므로 Circle에 존재하는 반지름 설정함수 setRadius(), 반지름 출력함수 getRadius()을 사용할 수 있다.

반응형
반응형

바로 그제 2021 05 19 암호화폐 하락장 중 저녁쯤에 대 폭락이 뜨면서 난리가 났었죠.

4월부터 각종 악재 속에 계속된 하락을 보여주면서 어제 새로운 저점을 보여주었습니다.

하지막 금방 회복하면서 현재 업비트 기준 5000 초반에서 4900후반대를 보여주고 바이낸스 기준 4400 후반을 보여주고 있네요.

 

하지만!

알트코인들은 그대로 회복도 못하고 사망했죠...(저도 알트..)

그래서인지 메이저 코인기반 비트코인, 이더리움, 클레이튼 으로 만들어진 코인들이 각광 받고 있습니다.

그 중 클레이튼 기반으로 만들어진 CowCow코인을 알아볼까 합니다.

 

일단 어제 핫빗 코리아에 상장되었는데..

24시간 고가 140.0 저가 20.2 현재가 50.1 거래량 530만 총발행량 2,000,000,000 Cow

역시 처음 상장되서 그런지 변동폭이 심하네요...

20원대에 들어갔으면..ㅎㅎ

하지만 다른 코인과 똑같이 처음 상장되서 아마 계속 하락세를 보일 듯 합니다.

그래도 장기로 본다면 최근에 저점을 찍고 온거 보면 상승 할지도...

 

또, 이 코인은 채굴도 가능합니다!

솔직히 요즘 스캠사기도 많고 불안하기도 했지만...

시스템 관리도 하고 다운로드 수도 많고 하는 거 보니 살짝 안심이 되기도 합니다.

 

https://play.google.com/store/apps/details?id=site.cowcow 추천인 코드 : 3KEDWT

 

CowCow | 카우카우 Crypto Mining - Google Play 앱

귀여운 COW와 함께 즐거운 블록체인 마이닝을 시작하세요. 카우카우 공지는 트위터로 확인하세요.

play.google.com

구글로만 로그인이 가능합니다!

 

게임화면

귀엽습니다.. ㅎㅎ

저는 컴퓨터로 다운받아서 그냥 켜놓고 다른거 합니다.

시간날때마다 보고...

오늘 시작했는데 다른코인에 비해 빠르긴하네요.

  

여물받기도 광고를 보면 하나씩 줍니다.

(1분의 지연시간 있습니다.)

여물로 캐셔야지 두배줍니다!!

 

여물로 보너스 게임도 가능 한데

도박입니다.

저는 5원까지 나와봤네요.. ㅎㅎ

나머지는 다 0.몇원대...

 

하루에 Level 1 기준 500,000 Cow 채굴 가능하며 누적된 창출의 채굴수가 일 정량 도달하면

Level이 상승된다고 하네요.

공급 제한 => 가치 상승

을 유도하는 것 같네요.

 

게임내에서 사용된다고 하는 Cow코인 가상농장 게임이라고 하는데

요즘 롤, 피파, 오버워치, 서든, 배그 등

대표적인 게임 제외하고 성공하는 게임들이 별로 보이지 않는 것 같아요.

너무 오래된 게임들인데...

 

그래서 많은 가상게임들이 준비 중인 것 같습니다. 

성공사례로는 포켓몬 고가 있죠.

 

사실상 게임이 성공해야 그 곳에서 쓰이는 코인이 대박납니다.

 

그나마 회복장인 지금 다들 성투하시길 바랍니다.

 

핫빗코리아 링크 입니다. https://www.hotbit.co.kr/

 

핫빗코리아

비트코인, 이더리움, 비트코인캐시, 리플, 이오스, 앞서가는 디지털 자산 거래소

www.hotbit.co.kr

 

반응형

'암호화폐' 카테고리의 다른 글

아모(AMO)코인 아모랩스(AMO Laps)  (1) 2021.05.24
클레이튼(Klaytn) 코인  (2) 2021.05.24
반응형

문제

정수 배열을 항상 증가 순으로 유지하는 SortedArray 클래스를 작성하려고 한다. 아래의 main() 함수가 작동할 만큼만 SortedArray 클래스를 작성하고 +와 = 연산자도 작성하라

class SortedArray {
	int size; //현재 배열의 크기
	int* p;
	void sort();
public:
	SortedArray(); //p는 NULL로 size는 0으로 초기화
	SortedArray(SortedArray& src); //복사 생성자
	SortedArray(int p[], int size); //생성자, 정수 배열과 크기를 전달받음
	~SortedArray(); //소멸자
	SortedArray operator +(SortedArray& op2); //현재 배열에 op2 배열 추가
	SortedArray& operator = (const SortedArray& op2); //현재 배열에 op2 배열 복사
	void show(); //배열의 원소 출력
};

int main()
{
	int n[] = { 2,20,6 };
	int m[] = { 10,7,8,30 };
	SortedArray a(n, 3), b(m, 4), c;

	c = a + b; // +, = 연산자 작성 필요
	// + 연산자가 SortedArray 객체를 리턴하므로 복사 생성자 필요

	a.show();
	b.show();
	c.show();
}

 

결과

배열 출력 : 2 6 20

배열 출력 : 7 8 10 30

배열 출력 : 2 6 7 8 10 20 30

 

소스코드

#include<iostream>
using namespace std;
class SortedArray {
	int size; //현재 배열의 크기
	int* p;
	void sort();
public:
	SortedArray(); //p는 NULL로 size는 0으로 초기화
	SortedArray(SortedArray& src); //복사 생성자
	SortedArray(int p[], int size); //생성자, 정수 배열과 크기를 전달받음
	~SortedArray(); //소멸자
	SortedArray operator +(SortedArray& op2); //현재 배열에 op2 배열 추가
	SortedArray& operator = (const SortedArray& op2); //현재 배열에 op2 배열 복사
	void show(); //배열의 원소 출력
};
void SortedArray::sort() //정렬함수
{
	int temp;
	for (int i = 0; i < this->size - 1; i++)
	{
		for (int j = i + 1; j < this->size; j++)
		{
			if (p[i] > p[j]) {
				temp = p[i];
				p[i] = p[j];
				p[j] = temp;
			}
		}
	}
}
SortedArray::SortedArray() //생성자
{
	p = nullptr;
	size = 0;
}
SortedArray::SortedArray(SortedArray& src) //복사생성자
{
	this->size = src.size;
	this->p = new int[this->size];
	for (int i = 0; i < this->size; i++)
		this->p[i] = src.p[i];
}
SortedArray::SortedArray(int p[], int size) //매개변수 생성자
{
	this->size = size;
	this->p = new int[size];
	for (int i = 0; i < size; i++)
		this->p[i] = p[i];
}
SortedArray::~SortedArray() //소멸자
{
	delete[] p;
}
SortedArray SortedArray::operator+(SortedArray& op2)
{
	SortedArray op3;
	op3.size = this->size + op2.size;
	op3.p = new int[op3.size];
	for (int i = 0; i < op3.size; i++)
	{
		if (i < this->size)
			op3.p[i] = this->p[i];
		else
			op3.p[i] = op2.p[i - this->size];
	}
	return op3;
}
SortedArray& SortedArray::operator=(const SortedArray& op2)
{
	this->size = op2.size;
	this->p = new int[this->size];
	for (int i = 0; i < this->size; i++)
	{
		this->p[i] = op2.p[i];
	}
	return *this;
}
void SortedArray::show()
{
	this->sort(); //정렬
	cout << "배열 출력 : ";
	for (int i = 0; i < this->size; i++)
		cout << this->p[i] << ' ';
	cout << endl;
}
int main()
{
	int n[] = { 2,20,6 };
	int m[] = { 10,7,8,30 };
	SortedArray a(n, 3), b(m, 4), c;

	c = a + b; // +, = 연산자 작성 필요
	// + 연산자가 SortedArray 객체를 리턴하므로 복사 생성자 필요

	a.show();
	b.show();
	c.show();
}
반응형

+ Recent posts