mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			31 lines
		
	
	
		
			765 B
		
	
	
	
		
			Solidity
		
	
	
	
	
	
			
		
		
	
	
			31 lines
		
	
	
		
			765 B
		
	
	
	
		
			Solidity
		
	
	
	
	
	
| contract test {
 | |
|     function f(uint256[] calldata seq) external pure returns (uint256) {
 | |
|         uint i = 0;
 | |
|         uint sum = 0;
 | |
|         while (i < seq.length)
 | |
|         {
 | |
|             uint idx = i;
 | |
|             if (idx >= 10) break;
 | |
|             uint x = seq[idx];
 | |
|             if (x >= 1000) {
 | |
|                 uint n = i + 1;
 | |
|                 i = n;
 | |
|                 continue;
 | |
|             }
 | |
|             else {
 | |
|                 uint y = sum + x;
 | |
|                 sum = y;
 | |
|             }
 | |
|             if (sum >= 500) return sum;
 | |
|             i++;
 | |
|         }
 | |
|         return sum;
 | |
|     }
 | |
| }
 | |
| // ====
 | |
| // compileToEwasm: also
 | |
| // ----
 | |
| // f(uint256[]): 32, 3, 1000, 1, 2 -> 3
 | |
| // f(uint256[]): 32, 3, 100, 500, 300 -> 600
 | |
| // f(uint256[]): 32, 11, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 111 -> 55
 |