SELECT 
  cscart_product_prices.product_id, 
  MIN(
    IF(
      cscart_product_prices.percentage_discount = 0, 
      cscart_product_prices.price, 
      cscart_product_prices.price - (
        cscart_product_prices.price * cscart_product_prices.percentage_discount
      )/ 100
    )
  ) AS price 
FROM 
  cscart_product_prices 
WHERE 
  cscart_product_prices.product_id IN (
    170, 162, 168, 61, 166, 736, 734, 732, 
    733, 735, 737, 1569, 258, 257, 1783, 
    1779, 1782, 1781, 1676, 1229, 1181, 
    362, 256, 452
  ) 
  AND cscart_product_prices.lower_limit = 1 
  AND cscart_product_prices.usergroup_id IN (0, 1) 
GROUP BY 
  cscart_product_prices.product_id

Query time 0.00117

JSON explain

{
  "query_block": {
    "select_id": 1,
    "table": {
      "table_name": "cscart_product_prices",
      "access_type": "range",
      "possible_keys": ["usergroup", "product_id", "lower_limit", "usergroup_id"],
      "key": "product_id",
      "key_length": "3",
      "used_key_parts": ["product_id"],
      "rows": 24,
      "filtered": 4.897957802,
      "index_condition": "cscart_product_prices.product_id in (170,162,168,61,166,736,734,732,733,735,737,1569,258,257,1783,1779,1782,1781,1676,1229,1181,362,256,452)",
      "attached_condition": "cscart_product_prices.lower_limit = 1 and cscart_product_prices.usergroup_id in (0,1)"
    }
  }
}

Result

product_id price
61 25000.00000000
162 18000.00000000
166 18000.00000000
168 18000.00000000
170 0.00000000
256 42000.00000000
257 70000.00000000
258 48000.00000000
362 52000.00000000
452 98000.00000000
732 42000.00000000
733 32000.00000000
734 40000.00000000
735 40000.00000000
736 42000.00000000
737 32000.00000000
1181 34000.00000000
1229 50000.00000000
1569 68500.00000000
1676 65000.00000000
1779 82000.00000000
1781 82000.00000000
1782 82000.00000000
1783 88000.00000000