U E D R , A S I H C RSS

PP Project/Colume2 Exercises

1. 3๋ฒˆ.

1.1.  €๊ธ€๋ง ๋ฐฉ‹ (JugglingAction)

  • Leonardongด ž‘„•œ ฝ”๋“œ
  • ด 4‹œ๊ฐ„ 8๋ถ„ธ๋ฆผ

~cpp 
#include <iostream> 
#include <string> 
using namespace std; 
 
string roll( string str,int n, int i ); 
int getGcd(int aN, int aM);

void main() 
{ 
	string str = "abcdefg"; 
	int n = str.length();
	int i;
	cout << "current : " << str << endl
		 << "shitf amount? : ";
	cin >> i;

	cout << "after shifting : " << roll(str, n, i) << endl;
} 

string roll( string str, int n, int i ) 
{
	if ( i % n != 0 )
		i %= n;
	int gcd = getGcd(n, i);
	char temp;
//	for ( int count = 0 ; count * gcd < i ; count ++ )
	for ( int count = 0 ; count < i ; count += gcd)
		for ( int tag = 0 ; tag < gcd ; tag++ ){
			temp = str[tag];
			for ( int base = tag ; base + gcd < n ; base += gcd)
				str[base] = str[base + gcd];
			str[base] = temp;
	}	
	return str;
}

int getGcd(int aN, int aM)
{
//assert aN > aM
	int remain;
	do{
		remain = aN % aM;
		aN = aM;
		aM = remain;
	}while( remain != 0 );

	return aN;
}
  • ž‘„•œ ›„
     €žฅ๊ณต๊ฐ„„ •˜๋‚˜๋ผ๋„ „ด๋ ค๊ณ  ๋ณ€ˆ˜๋ฅผ ตœ๋Œ€•œ •ˆ “ฐ๋ ค๊ณ  ๋…ธ๋ ฅ–ˆ๋‹ค. ‹ด ๋ณตžก•ดกŒ๋‹ค. ๊ฐ„๋‹จ•œ ž„‹œ๋ณ€ˆ˜๋Š” จค˜•ผ ๊ฒ ๋‹ค.

    ‹œ”„Šธ๋ฅผ ผ๋ฐ˜™”‹œผœ„œ ƒ๊ฐ•˜๊ณ  ๋ฌธ œ—  ‘๊ทผ–ˆ๋‹ค. •˜ง€๋งŒ ’€๋ฆฌง€ •Š•˜๋‹ค. …„ ๋‹ค‹œ ฝ๊ณ , ๊ทธ๋ฆผ„ ๋ด„œ ๋ฌด—‡„ ž˜ ๋ชป ด•ด–ˆ๋Š”ง€ ‚ดˆ๋‹ค. •˜ง€๋งŒ ž˜๋ชป ด•ด•œ ๋ถ€๋ถ„€ —†—ˆ๋‹ค. ‹œ๊ฐ„ด ง€๋‚˜๊ณ , ๋ฌธ œ๋ฅผ ๋‹ค‹œ ฝœผ๋ฉด žŒŠธ๋ฅผ –ปง€ •Š„๊นŒ •˜๋Š” ƒ๊ฐ— ๋ฌธ œ๋ฅผ ฝ—ˆ๋‹ค. ๋ฌธ œ—„œ ตœ๋Œ€๊ณต•ฝˆ˜๋ผ๋Š” ๋ง„ ‹ ๊ฒฝ“ฐง€ •Š•˜๋‹ค๋Š”  „ ๋ฐœ๊ฒฌ–ˆ๋‹ค. ตœ๋Œ€๊ณต•ฝˆ˜๋ฅผ ดšฉ•ด„œ ๊ฒฐ๊ตญ ๋ฌธ œ๋ฅผ •ด๊ฒฐ–ˆ๋‹ค.

    •ˆ ๋˜๋Š” ๋ฐฉ‹— ๋งค๋‹ฌ๋ฆฌ๋‹ค ๋ณด๋‹ˆ ŠฌŠฌ ๋‹ต๋‹ต•˜๊ณ  งœฆด ๋‚ฌ๋‹ค. ๋ญ”๊ฐ€ •„๋‹ˆ๋‹ค๋Š” ƒ๊ฐด ž๊พธ ๋“ค—ˆ๋‹ค.

    ฌ๊ฒŒ๋Š” ๊ฐ™€ •Œ๊ณ ๋ฆฌฆ˜๋„ ๋‹ค๋ฅธ ๋ฐฉ‹œผ๋กœ  ‘๊ทผ •  ˆ˜ žˆ๋‹ค.

    ๋ง‰žŒ๋‹ค๋Š” ๋А๋‚Œด ๋“ค๋ฉด, ๋ฌธ œ๋ฅผ ๋‹ค‹œ ด•ด•ด๋ณธ๋‹ค. HowToSolveIt—„œ ๋‚˜™”๋˜ ๋ฐœ œ๋ฅผ ŠคŠค๋กœ •ด๋ณธ๋‹ค. ด๋ฒˆ—๋Š” ๋นผ๋จน๊ณ  ๋„˜–ด๊ฐ„ กฐ๊ดžˆ๋Š”๊ฐ€?๋ผ๋Š” ๋ฐœ œ๋ฅผ ๋นจ๋ฆฌ –ˆ๋”๋ผ๋ฉด •ด๊ฒฐ •  ˆ˜ žˆ—ˆ„ ๊ฒƒด๋‹ค.

1.2. †๋’คง‘๊ธฐ ๋ฐฉ‹

  • Leonardong๊ณผ ™ฉžฌ„ ˜ PairProgramming
  • 30๋ถ„ธ๋ฆผ
    ~cpp 
    #include <iostream>
    #include <string>
    using namespace std;
    
    void reverse(string & str, int start, int end);
    
    void main()
    {
    	string str = "abcdefgh";
    	int n = str.size();
    	int i = 3;		//shift amount
    
    	int start, end;
    	start = 0;	end = i-1;
    	reverse( str, start, end);
    	start = i;	end = n-1;
    	reverse( str, start, end);
    	start = 0;	end = n-1;
    	reverse( str, start, end);
    	cout << str << endl;
    }
    
    void reverse(string & str, int front, int rear)
    {
    	char temp;
    	while( front < rear ){
    		temp = str[front];
    		str[front] = str[rear];
    		str[rear] = temp;
    		front++;
    		rear--;
    	}
    }
    

1.3. •Œ๊ณ ๋ฆฌฆ˜2

๋ฏธ•ด๊ฒฐ
32m†Œš”
~cpp 
#include <iostream>
#include <string>
using namespace std;



void swap(string & str, int start1, int end1, int start2, int end2){
	if ( end1 - start1 == end2 - start2){
		char temp;
		int limit = end1 - start1 + 1;
		for ( int i = 0 ; i < limit ; i++){
			temp = str[start1];
			str[start1] = str[start2];
			str[start2] = temp;
			start1++;
			start2++;
		}
	}
}



int main()
{
	string str= "abcdefg"; 
	int n = str.size();
	int i = 3;			// abc defg
	swap(str,0,i-1, n-i, n-1);
//	swap(str, 0, i-1, n - i, n-1);
//	swap(str, 0, i-1, i, n-i);
	cout << str << endl;
	return 0;
}


2. ›„๊ธฐ

™ฉžฌ„ 

๋‹ค†Œ —ฌœ ๋ฅผ ๊ฐ€ง€๊ณ  PairProgramming „ –ˆ๋‹ค. ˜ผž • ๋•Œ๋ณด๋‹ค ๋ฌธ œ ŒŒ•…ด ž˜ ๋˜—ˆ๊ณ  ๋ญ”๊ฐ€ ƒ Šธธ ๋А๋‚Œด ๋“ค—ˆ๋‹ค. •„‰ฌšด  ด๋ผ๋ฉด ๋ฌธ œ •ด๊ฒฐ— ๋„ˆ๋ฌด ๋งค๋‹ฌ๋ ค„œ ๋ฆฌŽ™† ๋ง„ ๊ฒŒ„๋ฆฌ•œ ๊ฒฐ๊ณผ šฐ•„•œ ”„๋กœ๊ทธ๋žจ„ ™„„•˜ง€ ๋ชป–ˆ๋‹ค. ๋Š˜ ๊ทธ๋ ‡๋“ฏด —ญ• — ๋งž๋Š” ๋ณ€ˆ˜๋ช… ๋ถ™ด๊ธฐ๋Š” –ด๋ ต๋‹ค. งง•˜ง€๋งŒ ฅ๋ฏธ„„•œ ‹œ๊ฐ„ด—ˆ๋‹ค.


Valid XHTML 1.0! Valid CSS! powered by MoniWiki
last modified 2021-02-07 05:24:00
Processing time 0.0130 sec