<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://mediawiki.zeropage.org/index.php?action=history&amp;feed=atom&amp;title=AustralianVoting%2FLeonardong</id>
	<title>AustralianVoting/Leonardong - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://mediawiki.zeropage.org/index.php?action=history&amp;feed=atom&amp;title=AustralianVoting%2FLeonardong"/>
	<link rel="alternate" type="text/html" href="https://mediawiki.zeropage.org/index.php?title=AustralianVoting/Leonardong&amp;action=history"/>
	<updated>2026-05-14T16:20:06Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.39.8</generator>
	<entry>
		<id>https://mediawiki.zeropage.org/index.php?title=AustralianVoting/Leonardong&amp;diff=28816&amp;oldid=prev</id>
		<title>imported&gt;Unknown at 05:22, 7 February 2021</title>
		<link rel="alternate" type="text/html" href="https://mediawiki.zeropage.org/index.php?title=AustralianVoting/Leonardong&amp;diff=28816&amp;oldid=prev"/>
		<updated>2021-02-07T05:22:33Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;미완&lt;br /&gt;
 #include &amp;amp;lt;iostream&amp;amp;gt; &lt;br /&gt;
 #include &amp;amp;lt;vector&amp;amp;gt; &lt;br /&gt;
 using namespace std; &lt;br /&gt;
  &lt;br /&gt;
 #define IntVector vector&amp;amp;lt;int&amp;amp;gt; &lt;br /&gt;
 #define CandidatorVector vector&amp;amp;lt;Candidator&amp;amp;gt; &lt;br /&gt;
 #define VoteSheetVector vector&amp;amp;lt;VoteSheet&amp;amp;gt; &lt;br /&gt;
 struct Candidator &lt;br /&gt;
 { &lt;br /&gt;
         char name[80]; &lt;br /&gt;
         int votedCount;&lt;br /&gt;
         bool fallen; &lt;br /&gt;
 }; &lt;br /&gt;
  &lt;br /&gt;
 struct VoteSheet &lt;br /&gt;
 { &lt;br /&gt;
    IntVector candidateNum; &lt;br /&gt;
 }; &lt;br /&gt;
  &lt;br /&gt;
 bool isWin( const Candidator &amp;amp;amp; candidator, int n ) &lt;br /&gt;
 { &lt;br /&gt;
         if ( candidator.votedCount &amp;amp;gt;= n / 2 ) &lt;br /&gt;
                 return true; &lt;br /&gt;
         return false; &lt;br /&gt;
 } &lt;br /&gt;
  &lt;br /&gt;
 int current( const VoteSheet &amp;amp;amp; sheet ) &lt;br /&gt;
 { &lt;br /&gt;
         return sheet.candidateNum.front(); &lt;br /&gt;
 } &lt;br /&gt;
  &lt;br /&gt;
 int pop_front( VoteSheet &amp;amp;amp; sheet ) &lt;br /&gt;
 { &lt;br /&gt;
         return *sheet.candidateNum.erase( sheet.candidateNum.begin() ); &lt;br /&gt;
 } &lt;br /&gt;
  &lt;br /&gt;
 void collectVoting( CandidatorVector &amp;amp;amp; candidators, const VoteSheetVector &amp;amp;amp; sheets ) &lt;br /&gt;
 { &lt;br /&gt;
         for ( int i = 0 ; i &amp;amp;lt; sheets.size() ; i++ ) &lt;br /&gt;
                 if ( candidators[ current(sheets[i]) ].fallen == false ) &lt;br /&gt;
                         candidators[ current(sheets[i]) ].votedCount++; &lt;br /&gt;
 } &lt;br /&gt;
  &lt;br /&gt;
 void markFall( CandidatorVector &amp;amp;amp; candidators, const int limit ) &lt;br /&gt;
 { &lt;br /&gt;
         for ( int i = 0 ; i &amp;amp;lt; candidators.size() ; i++ ) &lt;br /&gt;
                 if ( candidators[i].votedCount &amp;amp;lt;= limit ) &lt;br /&gt;
                         candidators[i].fallen = false; &lt;br /&gt;
 } &lt;br /&gt;
  &lt;br /&gt;
 int minVotedNum( const CandidatorVector &amp;amp;amp; candidators ) &lt;br /&gt;
 { &lt;br /&gt;
         int result = INT_MAX; &lt;br /&gt;
         for ( int i = 0 ; i &amp;amp;lt; candidators.size() ; i++ ) &lt;br /&gt;
                 if ( candidators[i].fallen == false) &lt;br /&gt;
                         if ( result &amp;amp;gt; candidators[i].votedCount ) &lt;br /&gt;
                                 result = candidators[i].votedCount; &lt;br /&gt;
         return result; &lt;br /&gt;
 } &lt;br /&gt;
  &lt;br /&gt;
 bool isUnionWin( const CandidatorVector &amp;amp;amp; candidators ) &lt;br /&gt;
 { &lt;br /&gt;
         for ( int i = 0 ; i &amp;amp;lt; candidators.size() ; i++ ) &lt;br /&gt;
                 if ( candidators[i].fallen == false ) &lt;br /&gt;
                         if ( candidators[i].votedCount != minVotedNum(candidators) ) &lt;br /&gt;
                                 return false; &lt;br /&gt;
         return true; &lt;br /&gt;
 } &lt;br /&gt;
  &lt;br /&gt;
 int countRemainCandidators( const CandidatorVector &amp;amp;amp; candidators ) &lt;br /&gt;
 { &lt;br /&gt;
         int result = 0; &lt;br /&gt;
         for ( int i = 0 ; i &amp;amp;lt; candidators.size() ; i++ ) &lt;br /&gt;
                 if ( candidators[i].fallen == false ) &lt;br /&gt;
                         result++;&lt;br /&gt;
         return result; &lt;br /&gt;
 } &lt;br /&gt;
 bool isSomeoneWin( const CandidatorVector &amp;amp;amp; candidators ) &lt;br /&gt;
 { &lt;br /&gt;
         int remainNum = countRemainCandidators(candidators); &lt;br /&gt;
         for ( int i = 0 ; i &amp;amp;lt; candidators.size() ; i++ ) &lt;br /&gt;
                 if ( isWin( candidators[i], remainNum ) )&lt;br /&gt;
                         return true; &lt;br /&gt;
         return false; &lt;br /&gt;
 } &lt;br /&gt;
 void main() &lt;br /&gt;
 { &lt;br /&gt;
 //        cin &amp;amp;gt;&amp;amp;gt; numOfCase; &lt;br /&gt;
 	int numOfCandidators;&lt;br /&gt;
     cin &amp;amp;gt;&amp;amp;gt; numOfCandidators; &lt;br /&gt;
 &lt;br /&gt;
 	char name[80];&lt;br /&gt;
 	CandidatorVector candidators;&lt;br /&gt;
 &lt;br /&gt;
 	int n = numOfCandidators;&lt;br /&gt;
 	cin.get();&lt;br /&gt;
     for ( int i = 0 ; i &amp;amp;lt; n ; i++ ){ &lt;br /&gt;
 		cin.getline( name, 80);&lt;br /&gt;
 		Candidator candidator;&lt;br /&gt;
 		strcpy( candidator.name, name );&lt;br /&gt;
 		candidator.votedCount = 0;&lt;br /&gt;
 		candidator.fallen = false;&lt;br /&gt;
 		candidators.push_back( candidator );&lt;br /&gt;
 	}&lt;br /&gt;
 	int vote;&lt;br /&gt;
 	VoteSheetVector sheets;&lt;br /&gt;
     for ( i = 0 ; i &amp;amp;lt; 5 ; i++ ){&lt;br /&gt;
 		VoteSheet sheet;&lt;br /&gt;
 		for ( int j = 0 ; j &amp;amp;lt; n ; j++ ) {&lt;br /&gt;
 			cin &amp;amp;gt;&amp;amp;gt; vote; &lt;br /&gt;
 			sheet.candidateNum.push_back( vote );&lt;br /&gt;
 		}&lt;br /&gt;
 		sheets.push_back( sheet );&lt;br /&gt;
 	}&lt;br /&gt;
 &lt;br /&gt;
 	int num;&lt;br /&gt;
     do{&lt;br /&gt;
 		for ( int i = 0 ; i &amp;amp;lt; n ; i++ ) {&lt;br /&gt;
 			num = pop_front(sheets[i]);&lt;br /&gt;
 			candidators[ num ].votedCount++;&lt;br /&gt;
 		}&lt;br /&gt;
 		markFall( candidators, minVotedNum( candidators ) );&lt;br /&gt;
 	}while( isUnionWin(candidators) &amp;amp;amp;&amp;amp;amp; isSomeoneWin(candidators) );&lt;br /&gt;
 	for ( i = 0 ; i &amp;amp;lt; n ; i++ )&lt;br /&gt;
 		if ( candidators[i].fallen == false )&lt;br /&gt;
 			cout &amp;amp;lt;&amp;amp;lt; candidators[i].name &amp;amp;lt;&amp;amp;lt; endl;&lt;br /&gt;
 }&lt;br /&gt;
&lt;/div&gt;</summary>
		<author><name>imported&gt;Unknown</name></author>
	</entry>
</feed>